Docker | dockerfile 文件编写

dockerfile 的作用

dockerfile 作用就是制作镜像,保持开发,测试,生产环境的一致性。

直接将容器制作为镜像

制作新的镜像

	# 把容器按照自己的需求个性完之后,就可以创建自己的镜像的
	docker commit 容器id 镜像名称:版本号

我们就使用在上篇中部署的nginx服务制作一个镜像Docker | 部署Nginx

image-20220105011245344

	docker commit 07388cf54586 frost_nginx:1.0

image-20220105011428123

压宿镜像

	docker save -o 压缩文件名称 镜像名称:版本号

image-20220105011712676

只有在容器内做的个性,在压缩的时候,才会打包到缩压文件中

解压镜像,并运行

	docker load -i 压缩文件名称

因为在测试环境,所以先删除这个镜像,再用压缩名进行还原

	docker load -i frost_nginx.tar

image-20220105011944848

使用dockerfile生成镜像

dockerfile 命令

关键字 作用 备注
FROM 指定父镜像 指定dockerfile基于那个image构建
MAINTAINER 作者信息 用来标明这个dockerfile谁写的
LABEL 标签 用来标明dockerfile的标签 可以使用Label代替Maintainer 最终都是在docker image基本信息中可以查看
RUN 执行命令 执行一段命令 默认是/bin/sh 格式: RUN command 或者 RUN [“command” , “param1″,”param2”]
CMD 容器启动命令 提供启动容器时候的默认命令 和ENTRYPOINT配合使用.格式 CMD command param1 param2 或者 CMD [“command” , “param1″,”param2”]
ENTRYPOINT 入口 一般在制作一些执行就关闭的容器中会使用
COPY 复制文件 build的时候复制文件到image中
ADD 添加文件 build的时候添加文件到image中 不仅仅局限于当前build上下文 可以来源于远程服务
ENV 环境变量 指定build时候的环境变量 可以在启动的容器的时候 通过-e覆盖 格式ENV name=value
ARG 构建参数 构建参数 只在构建的时候使用的参数 如果有ENV 那么ENV的相同名字的值始终覆盖arg的参数
VOLUME 定义外部可以挂载的数据卷 指定build的image那些目录可以启动的时候挂载到文件系统中 启动容器的时候使用 -v 绑定 格式 VOLUME [“目录”]
EXPOSE 暴露端口 定义容器运行的时候监听的端口 启动容器的使用-p来绑定暴露端口 格式: EXPOSE 8080 或者 EXPOSE 8080/udp
WORKDIR 工作目录 指定容器内部的工作目录 如果没有创建则自动创建 如果指定/ 使用的是绝对地址 如果不是/开头那么是在上一条workdir的路径的相对路径
USER 指定执行用户 指定build或者启动的时候 用户 在RUN CMD ENTRYPONT执行的时候的用户
HEALTHCHECK 健康检查 指定监测当前容器的健康监测的命令 基本上没用 因为很多时候 应用本身有健康监测机制
ONBUILD 触发器 当存在ONBUILD关键字的镜像作为基础镜像的时候 当执行FROM完成之后 会执行 ONBUILD的命令 但是不影响当前镜像 用处也不怎么大
STOPSIGNAL 发送信号量到宿主机 该STOPSIGNAL指令设置将发送到容器的系统调用信号以退出。
SHELL 指定执行脚本的shell 指定RUN CMD ENTRYPOINT 执行命令的时候 使用的shell

简单的dockerfile书写

	# 下载nginx安装包
	wget -c //nginx.org/download/nginx-1.12.2.tar.gz 

书写dockerfile文件:

# base image
FROM centos:7

# MAINTAINER
MAINTAINER frost <[email protected]>

# put nginx-1.12.2.tar.gz into /usr/local/src and unpack nginx
ADD nginx-1.12.2.tar.gz /usr/local/src

# running required command
RUN yum install -y gcc gcc-c++ glibc make autoconf openssl openssl-devel 
RUN yum install -y libxslt-devel -y gd gd-devel GeoIP GeoIP-devel pcre pcre-devel
RUN useradd -M -s /sbin/nologin nginx

# change dir to /usr/local/src/nginx-1.12.2
WORKDIR /usr/local/src/nginx-1.12.2

# execute command to compile nginx
RUN ./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-file-aio  --with-http_ssl_module  --with-http_realip_module    --with-http_addition_module    --with-http_xslt_module   --with-http_image_filter_module    --with-http_geoip_module  --with-http_sub_module  --with-http_dav_module --with-http_flv_module    --with-http_mp4_module --with-http_gunzip_module  --with-http_gzip_static_module  --with-http_auth_request_module  --with-http_random_index_module   --with-http_secure_link_module   --with-http_degradation_module   --with-http_stub_status_module && make && make install

ENV PATH /usr/local/nginx/sbin:$PATH

EXPOSE 80

ENTRYPOINT ["nginx"]

CMD ["-g","daemon off;"]

把安装包和dockerfile文件放在同一个目录下

image-20220105024453831

	# 执行编译命令
	docker build -t frost_test_nginx:1.0 .

image-20220105023938211

最终生成一个镜像:

image-20220105024233511

测试这个镜像

	docker run -d -p 80:80 --name=frost_nginx frost_test_nginx:1.0

image-20220105024356779


细节决定成败!
个人愚见,如有不对,恳请斧正!