There are so much useful tips out there, how to use docker. This great tips are part of blog posts, talks or within a documentation. I tought it might be useful, to collect all this docker best pratices, which are distributed all over these resources.
Feel free to add new best practices and create a PR.
Some installations create data, which are not be needed. Try to remove this data in the same layer.
RUN yum install -y epel-release && \
rpmkeys --import file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 && \
yum install -y --setopt=tsflags=nodocs bind-utils gettext iproute\
v8314 mongodb24-mongodb mongodb24 && \
yum -y clean all
For more detailed information see Container best practices.
Try to recude the number of layers, which will be created in your Dockerfile. Most Dockerfile instructions will add a new layer on top of the current image and commit the results.
For more detailed information see Best practices for writing Dockerfiles.
Use tags to reference specific versions of your image.
Tags could be used to denote a specific Docker container image. Hence, the tagging strategy must include leveraging a unique counter like build id
from a CI Server (eg: Jenkins) to help with identifying the right Image.
For more detailed information see The tag command.
Use --log-opt
to allow log rotation if the containers you are creating are too verbose and are created too often thanks to a continuous deployment process.
For more detailed information see the log driver options.
The creatation and startup time of a container should be as small as possible. In addition a container should shut down gracefully when the container receive a SIGTERM. This makes it easier to scale up or down. It also makes it easier to remove unhealthy containers and spwan new ones.
For more detailed information see The Tweleve-Factor App and Best practices for writing Dockerfiles.
If a container only has one responsibility, which should in almost all cases one process, it makes it much eaiser to scale horizontally or reuse the container in general.
Best practices for writing Dockerfiles.
If you services need to share data, use shared volumnes. Please make sure that you services are designed for concurrency data access (read and write).
For more detailed information see Manage data in containers.
Remove unnecessary layers in your registry.
For more detailed information see Garbage Collection.
Use a security scanner for your images for a static analysis of vulnerabilities.
For more detailed information see Docker Security Scanning or Clair.
If your service do not need root privileges, then do not run it with it. Create a new user and switch the user with USER
.
RUN groupadd -r myapp && useradd -r -g myapp myapp
USER myapp
For more detailed information see Best practices for writing Dockerfiles.
To handle logs in your service easily, write all your logs to stdout
. This uniform process makes it easy for docker deamon to grab this stream.
For more detailed information see The Tweleve-Factor App and Configure logging drivers.