dockerfile操作
简介
Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。
上下文路径
以下是一个简单的Dockerfile文件
FROM ubuntu:16.04
WORKDIR /home/test
RUN echo 'test' > /home/test.text
COPY test.txt /home/test.txt
如下是一个简单的基于dockerfile创建镜像的命令,我们注意到启动处理镜像名和tag之外,还有一个点,点就是代表上下文路径。
上下文路径是指 docker 在构建镜像,有时候想要使用到本机的文件(比如复制),docker build 命令得知这个路径后,会将路径下的所有内容打包。
默认情况下,Dockerfile所在路径就是上下文路径
注意:上下文路径下不要存放无用文件,会导致过程缓慢
执行时需要在Dockerfile存在的路径进行build
docker build -t ubuntu:v1 .
常用参数及含义
MAINTAINER
维护者信息,作者信息
FROM
创建的镜像都是基于FROM后面的镜像
RUN
执行后面的命令;相当于在shell中执行命令
对于多个指令不建议使用如下方法:
RUN command1
RUN command2
RUN command3
建议使用如下:
RUN command1 \
&& command2 \
&& command3
COPY
从上下文的对应路径拷贝文件到镜像中的对应路径
COPY 上下文的路径 容器中的路径
[--chown=<user>:<group>]:可选参数,用户改变复制到容器内文件的拥有者和属组。
ADD
使用与COPY类似,官方推荐COPY,ADD有如下优缺点
ADD 的优点:在执行 <源文件> 为 tar 压缩文件的话,压缩格式为 gzip, bzip2 以及 xz 的情况下,会自动复制并解压到 <目标路径>。
ADD 的缺点:在不解压的前提下,无法复制 tar 压缩文件。会令镜像构建缓存失效,从而可能会令镜像构建变得比较缓慢。具体是否使用,可以根据是否需要自动解压来决定。
CMD
功能与RUN类似,但是时间点不一致
RUN:docker build时候执行
CMD:docker run时候执行
作用:为启动的容器指定默认要运行的程序,程序运行结束,容器也就结束。CMD 指令指定的程序可被 docker run 命令行参数中指定要运行的程序所覆盖(COMMAND)。
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
如果有多行CMD, 则只有最后一行生效
# 可执行文件一般为sh脚本
CMD ["<可执行文件或命令>","<param1>","<param2>",...]
CMD ["<param1>","<param2>",...] # 该写法是为 ENTRYPOINT 指令指定的程序提供默认参数
ENTRYPOINT
类似于CMD与RUN,不过不会被docker run所覆盖,只有在docker run指定--entrypoint时覆盖,此标签类似与开机自启动某些程序,当出现多个ENTRYPOINT时,只有最后一个生效,格式如下
ENTRYPOINT ["<executeable>","<param1>","<param2>",...]
可以搭配CMD使用,作为变参
FROM nginx
RUN echo 'test' > /home/test.text \
&& cd /home
COPY readme.md /home/readme.md
ENTRYPOINT [ "nginx",'-c']
CMD ["/etc/nginx/nginx.conf"]
如上,dockerfile在编译时会自动调用nginx -c /etc/nginx/nginx.conf启动nginx
当进行传参时COMMNAD,--endpoint时则会被指令中的参数覆盖
ENV
设置环境变量,可以在后续的操作中使用:$PARAM,格式如下:
ENV <key> <value>
ENV <key1>=<value1> <key2>=<value2>...
ARG
与ENV类似,不过只在docker build的时候生效,
构建命令 docker build 中可以用 --build-arg <参数名>=<值> 来覆盖。
ARG <参数名>[=<默认值>]
VOLUME
创建数据卷,用于挂在本地数据(不断改变或者变大的数据),例如数据库等,防止因容器异常导致数据丢失,减少容器的容量,格式如下:
VOLUME [“/data”]
VOLUME ["<路径1>", "<路径2>"...]
EXPOSE
对外暴露端口,方便互联,在运行时使用随机端口映射时,也就是 docker run -P 时,会自动随机映射 EXPOSE 的端口。
EXPOSE <端口1> [<端口2>...]
WORKDIR
为后续的 RUN、CMD、ENTRYPOINT 指令配置工作目录。
格式如下:
WORKDIR <工作目录路径>
可以多个WORKDIR,路径则为拼接,例如
WORKDIR a
WORKDIR b
WORKDIR c
# 工作目录为/a/b/c
USER
切换后续动作的用户、用户组,需保证当前存在用户或者用户组,格式如下:
USER <用户名>[:<用户组>]
USER daemon
ONBUILD
延迟执行,在其他dockcerfile FROM此镜像时会触发,格式如下:
ONBUILD <其它指令>
LABEL
添加元数据,以键值对形式展示
LABEL <key>=<value> <key>=<value> <key>=<value> ...
注意事项
1.当使用Dockerfile创建镜像后,创建新容器无法持续运行时,需要注意是否添加了ENDPOINT,并且执行的指令是否是阻塞的,可以使用如下方式实现阻塞
tail -f 执行的文件
2.当容器创建或者运行出现问题时,可以使用docker inspect 容器id 查看Logpath中的log位置查看log
总结
FROM:基于哪个镜像进行创建
RUN:docker build时执行命令,每调用一次则新建一层
COPY:从上下文路径拷贝对应文件到镜像中
ADD:与COPY类似都是拷贝文件,对于tar压缩包会自动解压
CMD:docker run时执行的命令,会被docker run的COMMAND参数所覆盖
ENTRYPOINT:创建镜像后进入容器执行相关指令,可以将CMD中的参数作为变参
ENV:设置环境变量值,方便后续直接取
ARG:设置值,但只在docker build时候生效
VOLUME:挂载磁盘卷,防止数据丢失,例如数据库等
EXPOSE:对外暴露端口,方便互联
WORKDIR:设置工作目录,会影响到后续操作
USER:切换用户组,会影响到后续操作
ONBUILD:当其他镜像FROM时执行指令
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律