.dockerignore
文件是一个文本文件,告诉 Docker 在构建镜像时应该忽略哪些文件或目录。这个文件的作用类似于 .gitignore
,用于排除不需要包含在 Docker 镜像中的文件或目录,以减少镜像的大小和提高构建速度。
.dockerignore
文件的格式
- 每行一个模式,用于指定需要忽略的文件或目录。
- 支持通配符:
*
、?
和[]
。 - 注释:以
#
开头的行会被忽略,通常用于注释说明。 - 支持相对路径:文件和目录的路径是相对于构建上下文目录的。
常用的 .dockerignore
文件规则
-
忽略某个特定文件或目录:
- 忽略某个文件:
file.txt
- 忽略某个目录:
dir/
- 忽略某个文件:
-
使用通配符:
*
:匹配零个或多个字符。?
:匹配一个字符。[]
:匹配括号中指定范围内的字符。
-
排除文件(以
!
开头):!
用于取消忽略某个文件或目录,即将原本会被忽略的文件或目录包括进来。
-
支持注释:
#
后面的是注释内容,不会被 Docker 处理。
示例 .dockerignore
文件
# 忽略所有的 .git 文件夹和文件
.git/# 忽略所有的临时文件
*.tmp# 忽略所有的日志文件
*.log# 忽略某个特定的文件
config.json# 忽略某个目录
test/# 忽略所有的编译产物
*.o
*.pyc
*.class# 排除某些文件,即使它们匹配了忽略规则
!src/main.py# 排除目录中的特定文件或目录
!src/somefile.txt# 忽略文件夹中所有的内容,但保留空目录
dir/*
!dir/.keep
解释
.git/
:忽略.git
目录,这是 Git 存储版本控制信息的地方,通常不需要放进 Docker 镜像。*.tmp
:忽略所有扩展名为.tmp
的文件。*.log
:忽略所有.log
扩展名的日志文件。config.json
:忽略config.json
文件。test/
:忽略test
目录下的所有文件。*.pyc
和*.class
:忽略编译过程中生成的 Python.pyc
和 Java.class
文件。!src/main.py
:排除src/main.py
文件,虽然*.py
会匹配 Python 文件,但是这个规则表示明确将main.py
包括进 Docker 镜像。dir/*
和!dir/.keep
:忽略dir
目录下所有文件,但是保留空目录(通过.keep
文件来保持目录存在)。
使用 .dockerignore
的好处
- 减小镜像体积:通过忽略不必要的文件,可以大大减小 Docker 镜像的体积。
- 提高构建速度:避免将大量不必要的文件发送到 Docker 守护进程,从而加速镜像的构建过程。
- 提高安全性:通过忽略某些文件(如
.git
或包含敏感信息的配置文件),减少暴露在 Docker 镜像中的不必要内容。
.dockerignore
的一些最佳实践
- 忽略版本控制文件:如
.git/
、.svn/
等。 - 忽略临时文件:如编辑器生成的临时文件(
.swp
)、系统生成的缓存文件(*.log
、*.tmp
)等。 - 忽略编译输出:如
.pyc
、.class
等。 - 排除敏感信息:避免将包含密码、密钥或数据库配置的文件包含在镜像中。
- 忽略文档和测试文件:一般情况下,测试文件和文档不需要在生产环境的镜像中出现。
通过合理配置 .dockerignore
文件,你可以确保 Docker 镜像只包含必需的文件,从而提高构建效率和镜像质量。