内容简介:Dockerfiler is a tool for declaratively managing images built from a set of Dockerfiles.See it in action in onThis isn't for managing images built from your own projects, which will typically have their own processes for building and deploying artifacts. I
Dockerfiler ( GitHub ) ( Docker Hub )
Dockerfiler is a tool for declaratively managing images built from a set of Dockerfiles.
See it in action in on the dockerized-tools repo , managing the images found here .
This isn't for managing images built from your own projects, which will typically have their own processes for building and deploying artifacts. Instead, this is for those tools that you use in development or in CI which can benefit from Docker as a distribution mechanism. Docker is an excellent means of distributing those sorts of tools . Dockerfiler helps you maintain a library (public or private) of images that you control.
Note that Dockerfiler never destroys data. It never deletes repositories/images/tags (even if they're present in the registry but missing from the manifest passed in). It does not modify image contents if a tag is already present in the registry; it doesn't check content at all, just presence of the tag, and leaves anything alone if it's already there. Dockerfiler will only append to the registry.
Supported registries: Docker Hub, Artifactory, ECR.
Example
Dockerfiler takes your image manifest on stdin and prints a sequence of docker
commands to stdout.
Suppose we give this manifest.json as input to Dockerfiler on stdin:
{ "myuser/openssl": [ { "type": "build", "dockerfile_path": "openssl.Dockerfile", "tags": { "1.1.1g": { "PACKAGE_VERSION": "1.1.1g-r0" } } } ], "myuser/terraform": [ { "type": "mirror", "source_reference": "hashicorp/terraform", "tags": { "0.12.27": null, "0.12.28": null } } ] }
and suppose that myuser/terraform:0.12.27
already exists in our registry, but myuser/openssl:1.1.1g
and myuser/terraform:0.12.28
don't. We invoke Dockerfiler:
$ docker run -i --rm dockerizedtools/dockerfiler:v0.1.0 --push < manifest.json set -ex docker build -t myuser/openssl:1.1.1g --build-arg TAG="1.1.1g" --build-arg PACKAGE_VERSION="1.1.1g-r0" -f openssl.Dockerfile . docker push myuser/openssl:1.1.1g docker pull hashicorp/terraform:0.12.28 docker tag hashicorp/terraform:0.12.28 myuser/terraform:0.12.28 docker push myuser/terraform:0.12.28
The myuser/terraform:0.12.27
tag already in the registry is left alone. Only the new tags get built and pushed.
This output is a list of commands which is not executed. Think of it as a dry run. If we actually want to execute these steps, we would pipe that output to a shell where we have credentials to do the docker push
.
Usage
Dockerfiler should be invoked as a Docker image:
$ alias dockerfiler='docker run -i --rm ... dockerizedtools/dockerfiler:v0.1.0' $ dockerfiler --registry-username myuser | bash
Docker Hub, Artifactory and ECR are supported as registries. Dockerfiler's interaction with the registries is limited to
- Read-only access to list repositories and tags
- For registries where repositories aren't lazily created upon push (ECR), also creates repositories as needed
Note that Dockerfiler doesn't build or push images itself. It outputs a list of docker
commands which can be piped to a shell to be executed in an environment with docker push
access.
Example of Dockerfiler being used in GitHub Actions to push to Docker Hub
Command line arguments
-
--registry [specification]
: what Docker registry to point at.-
Docker Hub: omit this or specify
dockerhub
-
Artifactory:
artifactory://<host>
(e.g.--registry artifactory://yourdomain.jfrog.io
) -
ECR:
ecr://<host>
(e.g.--registry ecr://0123456789012.dkr.ecr.us-east-1.amazonaws.com
)Only one registry is supported at a time. To push to multiple registries, call Dockerfiler more than once with different registry specifications.
-
-
--registry-username [username]
: username for the registry, if applicable.-
ECR doesn't require a username, but AWS credentials must be provided instead. Usually, this will be via environment variables
AWS_ACCESS_KEY_ID
/etc. orAWS_PROFILE
. Please be aware that these will need to be made available in the container running Dockerfiler. That may look like:$ docker run -i --rm -v ~/.aws:/.aws -u $(id -u):$(id -g) -e AWS_PROFILE dockerizedtools/dockerfiler:v0.1.0 ...
-
This can alternately be supplied as an environment variable
REGISTRY_USERNAME
.
-
-
--registry-password [password]
: password for the registry user, if applicable.--registry-username REGISTRY_PASSWORD
-
--push
: if supplied, Dockerfiler will outputdocker push
commands. By default, this is off, which is useful for validating which images will be built (and/or that they build successfully). -
--repository-prefix [prefix]
: optional prefix to put on all repository names.-
If the manifest JSON lists a repository like
project1
and--repository-prefix myuser/
is passed, then Dockerfiler will operate on the repositorymyuser/project1
. This can be useful for using the same manifest in multiple registries.
-
If the manifest JSON lists a repository like
-
--target [repository:tag]
: process just the image/tag specified. This is only for development use, validating that a given image can build successfully. There is no interaction with the registry, so no credentials are required.
Manifest format
The image manifest passed in on stdin is a JSON map with repository names as keys, and a list of image definitions as values. The image definitions can be either "mirror" image definitions, mirroring tags of an image published elsewhere, or "build" image definitions which get built from a Dockerfile that you supply.
Here's a full example:
{ "myuser/tool1": [ { "type": "build", "dockerfile_path": "tool1.Dockerfile", "build_context": "tool1context", "tags": { "v1": null, "v2": { "SOME_ARGUMENT": "1.2.3" } } }, { "type": "mirror", "source_reference": "anotheruser/tool1", "tags": { "v1beta": null } } ], ... }
It can be useful to have more than one image definition (i.e. more than one element in the list) when, for instance, you switch from using a publicly available image to building your own, or your normal Dockerfile for the tool installs from a binary, but some situation calls for a different Dockerfile which builds from source.
Each tag listed in the image definition can specify a map of build arguments that will be passed to docker build
. The tag will always, itself, be passed as a build argument TAG
. If no other build arguments are necessary, specify null
as the value for the tag.
The build_context
parameter for a "build" image definition is optional (defaulting to .
). This controls the last argument to docker build
, i.e. which files are provided as context during the docker build
.
For more detail on the schema of this data, refer to dockerfiler/image_definition.py .
Dockerfiles
See the discussion above about specifying build arguments and build context. Here's an example Dockerfile making use of the TAG
build argument:
FROM python:3.8.3-alpine3.12 ARG TAG RUN pip install flake8==$TAG ENTRYPOINT ["flake8"]
Here's one using build context to add an entrypoint script:
FROM alpine:3.12 COPY entrypoint.sh /usr/bin ENTRYPOINT ["entrypoint.sh"]
This would require that your manifest includes a build_context
pointing at the directory containing entrypoint.sh
.
If you supply a build argument which should control the base image, note that you must declare ARG
before FROM
:
ARG ALPINE_VERSION FROM alpine:$ALPINE_VERSION RUN ...
FAQ
-
Why does this print
docker
commands instead of building/pushing by itself? The current implementation is simple in some nice ways: no need to operate on the Docker socket, no need to reinvent the wheel of displaying build/push progress, no need to pass registry credentials with write access, no need to actually have access to your Dockerfiles or build context. It's easy to do a dry run, easy to test the tool (both for development and for actual use). Unix philosophy, separation of concerns, etc. This tool could work in other ways, but there are some benefits to doing it like this. -
What's the point of
mirror
? Docker tags are mutable, so it's often useful to simply take somebody else's image and make your own copy that you control. If you're pointing at a public image, you run the risk of the image being removed, or its contents changing over time. -
Why no delete?As mentioned at the top, Dockerfiler never deletes images, and it doesn't inspect image contents. The risks/rewards there are not favorable.
-
Will the image's Dockerfile show up on Docker Hub?Unfortunately, no. You may want to set up a repository description/README linking to the responsible Dockerfile.
-
Why use this instead of Docker Hub's automated builds?Dockerfiler can be used to automate builds/pushes to private registries, including non-Docker-Hub registries.
Contributing
Contributions are always appreciated.
Development
Development uses docker
, docker-compose
, and make
.
To run tests:
$ make test-setup $ make test # iterate here $ make test-cleanup
To format and run code checks:
$ make format check
See the Makefile for more details.
CI
CI happens in GitHub Actions:
- Upon any push, code checks and tests run
- Upon release, an artifact is built and pushed to Docker Hub ( dockerizedtools/dockerfiler )
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。