Understanding image builds

    OKD uses Kubernetes by creating containers from build images and pushing them to a container image registry.

    Build objects share common characteristics including inputs for a build, the requirement to complete a build process, logging the build process, publishing resources from successful builds, and publishing the final status of the build. Builds take advantage of resource restrictions, specifying limitations on resources such as CPU usage, memory usage, and build or pod execution time.

    The OKD build system provides extensible support for build strategies that are based on selectable types specified in the build API. There are three primary build strategies available:

    • Source-to-image (S2I) build

    • Custom build

    The resulting object of a build depends on the builder used to create it. For docker and S2I builds, the resulting objects are runnable images. For custom builds, the resulting objects are whatever the builder image author has specified.

    Additionally, the pipeline build strategy can be used to implement sophisticated workflows:

    • Continuous deployment

    OKD uses Buildah to build a container image from a Dockerfile. For more information on building container images with Dockerfiles, see the Dockerfile reference documentation.

    The custom build strategy allows developers to define a specific builder image responsible for the entire build process. Using your own builder image allows you to customize your build process.

    A custom builder image is a plain container image embedded with build process logic, for example for building RPMs or base images.

    Custom builds run with a high level of privilege and are not available to users by default. Only users who can be trusted with cluster administration permissions should be granted access to run custom builds.

    The Pipeline build strategy is deprecated in OKD 4. Equivalent and improved functionality is present in the OKD Pipelines based on Tekton.

    Jenkins images on OKD are fully supported and users should follow Jenkins user documentation for defining their in a job or store it in a Source Control Management system.

    The Pipeline build strategy allows developers to define a Jenkins pipeline for use by the Jenkins pipeline plug-in. The build can be started, monitored, and managed by OKD in the same way as any other build type.