Docker镜像的构成__Dockerfile

相比docker commit来说,Dockerfile的方法会更加自动化,更加方便快捷,而且功能也更强大。拿构建Nginx容器举例。

先创建一个目录

mkdir /opt/docker-file

进入目录

cd /opt/docker-file/

然后创建一个nginx目录并进入,创建一个Dockerfile文件并写入一些命令

cd nginx
vim Dockerfile
#This is my docker file

#Version 1 
#Auth Wt

#Base
FROM centos                           #基础镜像是centos,后面跟有效的镜像名(如果该镜像你的本地仓库没有则会从远程仓库Pull取)。后面的指令在些镜像中执行
MAINTAINER wt                            #告诉别人,是谁创建的(维护者信息)
ADD pcre-8.39.tar.gz /usr/local/src               #打包一些文件(这里是下载好之后的,下载好的文件必须也是同级目录,这里使用ADD命令,如果是一个压缩包不需要解压命令,它会自动帮我们解压)
ADD nginx-1.13.4.tar.gz /usr/local/src
RUN yum install -y wget gcc gcc-c++ make openssl-devel   #执行一些系统命令,每一条RUN指令(可能会有多条linux命令)会在当前容器最上面的可读写层执行并且提交成一个新的镜像层,接下来的指令会在这个新的镜
像层里执行。 RUN useradd
-s /sbin/nologin -M www WORKDIR /usr/local/src/nginx-1.13.4            #进入指定目录工作。 RUN ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --with-pcre=/usr/local/src/pcre-8.39 && make && make install RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf     #修改nginx自启动 ENV PATH /usr/local/nginx/sbin:$PATH EXPOSE 80                                 #指定容器对外暴露的端口号。 CMD ["nginx"]                            #指定你制作出来的镜像在启动成容器时运行命令的默认的参数。

Dockerfile 写完之后开始构建

docker build -t nginx-file:v1 /opt/docker-file/nginx

接下来就可以看到每一步的操作了,每一步都有一个ID,都是一个层级。

最后访问宿主机的IP就可以看到Nginx的欢迎界面了。

当然此案例只是一个入门,做到更深入全面的操作还需要更多的实际项目参与。

 

原文地址:https://www.cnblogs.com/wt645631686/p/7443170.html