This directory contains the Dockerfiles that specify the container images used for IREE. Images are uploaded to Google Container Registry (GCR).
To build an image, use docker build
, e.g.:
docker build build_tools/docker/cmake --tag cmake
To explore an image interactively, use docker run
, e.g.
docker run --interactive --tty --rm cmake
Production versions of the images can be downloaded from GCR:
docker pull gcr.io/iree-oss/cmake:prod
You can find more information in the official Docker docs.
We use multi-stage builds to limit duplication in our Dockerfiles and reduce the final image size. There is still duplication in cases where it's difficult to determine the correct files to copy.
IREE images follow a consistent structure. The image defined by build_tools/docker/foo-bar/Dockerfile
is uploaded to GCR as gcr.io/iree-oss/foo-bar
. It may be tagged as latest
or prod
, e.g. gcr.io/iree-oss/foo-bar:latest
. Dockerfile image definitions should list their dependencies based on these image names.
We use a helper python script to manage the Docker image deployment. It lists all images and their dependencies and manages their canonical registry location. This script pushes images to GCR which requires the Storage Admin
role in the iree-oss
GCP project.
When creating a new image, add it to the mapping in this script. To build an image and all images it depends on as well as pushing them to GCR and updating all references to the image digest.
python3 build_tools/docker/manage_images.py --image cmake
For multiple images
python3 build_tools/docker/manage_images.py --image cmake --image bazel
There is also the special option --image all
for all registered images.
python3 build_tools/docker/manage_images.py --image all
Update the Dockerfile
for the image that you want to modify or add. If you're adding a new image, or updating the dependencies between images, be sure to update IMAGES_TO_DEPENDENCIES
in manage_images.py
as well. If you are adding new images, it is best add them via git add
before proceeding.
Build the image, push the image to GCR and update all references to the image with the new GCR digest:
python3 build_tools/docker/manage_images.py --image "${IMAGE?}"
Test that the changes behave as expected locally and iterate on the steps above.
Commit the changes and send a PR for review. The CI will use the updated digest references to test the new images.
Merge your PR after is approved and all CI tests pass. Please remember to complete the step below.
:prod
tagKokoro builds preload images tagged with prod
on VM creation, so after changing the images used, you should also update the images tagged as prod
in GCR. This also makes development significantly easier for others who need to modify the docker
images.
We use build_tools/docker/prod_digests.txt
as a source of truth for which versions of the images on GCR should have the :prod
tag. The following command will ensure that you are at upstream HEAD on the main
branch before it updates the tags.
python3 build_tools/docker/manage_prod.py