Docker builds from Dockerfiles need access to the Docker Socket and are therefore inherently insecure: https://docs.docker.com/engine/security/security/#/docker-daemon-attack-surface. For this reason most multi-tenant container platforms do not support Docker builds. While OpenShift Container Platform, on which APPUiO is based, improves the security of builds through the use of SELinux, they are still not secure enough to run on a multi-tenant platform. Indeed we have we have disabled the custom build strategy (custom builders) on APPUiO for this reason.
However, since we regard building Docker images from Dockerfiles as a vital feature, APPUiO provides its own mechanism called the "APPUiO secure Docker builder" to offer this. APPUiO secure Docker builder has the following features:
- It provides the same user experience as the OpenShift Container Platform Docker builder.
- Builds run in virtual machines dedicated to a single APPUiO project, which in turn run on dedicated hosts, i.e. outside of APPUiO's OpenShift Container Platform. Therefore providing full isolation between builds and customer containers as well as between builds from different customers.
- Supports Docker cache for fast subsequent builds.
- All communication between APPUiO's OpenShift Container Platform and the dedicated build VMs is encrypted.
- To compensate the loss of custom builders it provides hooks to allow users to run a script before and/or after
docker build
.
RHEL and Docker versions in the build VMs are identical the ones on APPUiOs OpenShift Container Platform.
Users can add .d2i/pre_build
and/or .d2i/post_build
scripts to the source repository where their
Dockerfile
resides. The scripts
- need to be executable and can be written in any language.
- have access to environment variables set in the
BuildConfig
pre_build
is executed just beforedocker build
and has read/write to the Docker context, including theDockerfile
post_build
is executed just afterdocker build
and has access to the Docker context and the built image- are executed in the build VM as
root
Here you'll find an example which uses a pre_build
script to install Maven and uses it to download a .war
file from an artefact repository: https://github.com/appuio/appuio-docker-builder-example. The Dockerfile
picks up the .war
file downloaded by the pre_build
script and adds to the image with an ADD
instruction. In a real project the ARTIFACT
environment variable would be configure in a BuildConfig
. The example uses JBoss EAP, which is only available to you if you ordered it. However this approach also works with other base images.
- The OpenShift Container Platform Docker builder adds an
ENV
and aLABEL
instructions containing information about the image source at end of theDockerfile
. This is not yet implemented in the APPUiO secure Docker builder. - Binary and image sources are currently not implemented.