[toc]
Docker 配置安装Dockerfile
一、Dockerfile创建镜像 – Dockerfile格式
之前我们有说过创建镜像有多种模式:①通过容器创建镜像②使用模板创建镜像③Dockfile创建镜像
最后一条也即是我们今天所要讲的,通过Dockfile来创建镜像。
1. FROM //指定基于哪个基础镜像(docker images 所列出的images)
格式 FROM 或者 FROM :, 比如
FROM centos
FROM centos:latest
2. MAINTAINER //指定作者信息(可有可无)
格式 MAINTAIN ,比如
MAINTAINER xavi [email protected]
3. RUN //镜像操作指令(用来指定使用的命令)
格式为 RUN 或者 RUN [“executable”, “param1”, “param2”],比如
RUN yum install httpd
RUN ["/bin/bash", "-c", "echo hello"]
4. CMD // 三种格式:
CMD ["executable", "param1", "param2"]
CMD command param1 param2
CMD ["param1", "param2"]
RUN和CMD看起来挺像,但是CMD用来指定容器!!启动时!!用到的命令,!!只能有一条!! 比如:
CMD ["/bin/bash", "/usr/local/nginx/sbin/nginx", "-c", "/usr/local/nginx/conf/nginx.conf"]
5. EXPOSE 格式为 EXPOSE [...] ,
比如
EXPOSE 22 80 8443
这个用来指定要映射出去的端口,比如容器内部我们启动了sshd和nginx,所以我们需要把22和80端口暴漏出去。这个需要配合-P(大写)来工作,也就是说在启动容器时,需要加上-P,让它自动分配。如果想指定具体的端口,也可以使用-p(小写)来指定。
6. ENV //环境变量格式 ENV ,
比如
ENV PATH /usr/local/mysql/bin:$PATH
它主要是为后续的RUN指令提供一个环境变量,我们也可以定义一些自定义的变量: ENV MYSQL_version 5.6
7. ADD 格式 add 将本地的一个文件或目录拷贝到容器的某个目录里。 其中src为Dockerfile所在目录的相对路径,它也可以是一个url。比如
ADD
ADD http://www.asd.com/1.txt /usr/local/src //指定网络下载
8. COPY 格式同add,使用方法和add一样,不同的是, !! 它不支持url !!
9. ENTRYPOINT 格式类似CMD,容器启动时要执行的命令,它和CMD很像,也是只有一条生效,如果写多个只有最后一条有效。
和CMD不同是:CMD 是可以被 docker run 指令覆盖的,而ENTRYPOINT不能覆盖。
比如,容器名字为asd9577
我们在Dockerfile中指定如下CMD:
CMD ["/bin/echo","test"]
启动容器的命令是 docker run asd9577 这样会输出 test
假如启动容器的命令是 docker run -it asd9577 /bin/bash 什么都不会输出
ENTRYPOINT不会被覆盖,而且会比CMD或者docker run指定的命令要靠前执行
ENTRYPOINT ["echo", "test"]
docker run -it asd9577 123
则会输出 test 123 ,这相当于要执行命令 echo test 123
所以我在编辑Dockfile的时候一般都是选用ENTRYPOINT而不是选择CMD 因为有被覆盖的缺陷。
10. VOLUME
格式 VOLUME ["/data"]
创建一个可以从本地主机或其他容器挂载的挂载点。
11. USER //不经常用
格式 USER daemon
指定运行容器的用户
12. WORKDIR
格式 WORKDIR /path/to/workdir
为后续的RUN、CMD或者ENTRYPOINT指定工作目录
二、使用Dockfile 来安装配置nginx服务:
2.1 编辑Dockerfile
vim Dockerfile //内容如下
## Set the base image to CentOS
FROM centos
# File Author / Maintainer
MAINTAINER xavi [email protected]
# Install necessary tools
RUN yum install -y pcre-devel wget net-tools gcc zlib zlib-devel make openssl-devel
# Install Nginx
ADD http://nginx.org/download/nginx-1.8.0.tar.gz .
RUN tar zxvf nginx-1.8.0.tar.gz
RUN mkdir -p /usr/local/nginx
RUN cd nginx-1.8.0 && ./configure --prefix=/usr/local/nginx && make && make install
RUN rm -fv /usr/local/nginx/conf/nginx.conf
ADD http://www.apelearn.com/study_v2/.nginx_conf /usr/local/nginx/conf/nginx.conf
# Expose ports
EXPOSE 80
# Set the default command to execute when creating a new container
ENTRYPOINT /usr/local/nginx/sbin/nginx && tail -f /etc/passwd
详解如下:
## Set the base image to CentOS
FROM centos //docker images 出现的镜像
# File Author / Maintainer
MAINTAINER xavi [email protected] //指定用户信息
# Install necessary tools
RUN yum install -y pcre-devel wget net-tools gcc zlib zlib-devel make openssl-devel //安装必须的插件
# Install Nginx
ADD http://nginx.org/download/nginx-1.8.0.tar.gz . //下载nginx的源码包到本地当前目录
RUN tar zxvf nginx-1.8.0.tar.gz //解压
RUN mkdir -p /usr/local/nginx //级联创建nginx目录
RUN cd nginx-1.8.0 && ./configure --prefix=/usr/local/nginx && make && make install //进入目录编译并安装
RUN rm -fv /usr/local/nginx/conf/nginx.conf //删除原配置文件
ADD http://www.apelearn.com/study_v2/.nginx_conf /usr/local/nginx/conf/nginx.conf //下载配置好的nginx配置文件到指定目录
# Expose ports
EXPOSE 80 //映射出去的端口
# Set the default command to execute when creating a new container
ENTRYPOINT /usr/local/nginx/sbin/nginx && tail -f /etc/passwd //设置开机启动的命令(有仔细的朋友可能已经发现 为什么需要 tail -f 呢?其实很多人认为这是一个bug 如果你不添加这个当执行完他就会退出)
2.2 开始创建镜像(同时开启一个docker镜像服务)
//名字一定要命名为 Dockerfile 不然docker build是找不到文件的,-t 指定容器的名字(不可以出现大写字母), 后面的 . 指定去哪儿找Dockerfile
docker build -t centos_nginx .
有报警,然后中断,再次运行后成功!
最后我们可以看到如下成功的提示:
Successfully built 1f654937dd3b
Successfully tagged centos_nginx_n:latest
检查新的镜像是否已经生成:已经生成centos_nginx
[root@xavi ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos_nginx latest b92736976557 3 minutes ago 352MB
centos_with_nginx latest 9539596d8741 24 hours ago 602MB
192.168.72.130:5000/ubuntu latest 113a43faa138 4 weeks ago 81.2MB
ubuntu latest 113a43faa138 4 weeks ago 81.2MB
centos latest 49f7960eb7e4 4 weeks ago 200MB
registry latest d1fd7d86a825 5 months ago 33.3MB
2.3 创建容器并检查:
[root@xavi ~]# docker run -itd -p 81:80 centos_nginx bash
aeec1bd1bd2b6e7d7b4a8202d33490c537411d7a842bc333e168fea216ad8675
[root@xavi ~]# docker exec -it aeec1bd1 bash
[root@aeec1bd1bd2b /]# ps aux| grep nginx
root 1 0.1 0.0 11684 1344 pts/0 Ss+ 03:47 0:00 /bin/sh -c /usr/local/nginx/sbin/nginx && tail -f /etc/passwd bash
root 6 0.0 0.0 24884 792 ? Ss 03:47 0:00 nginx: master process /usr/local/nginx/sbin/nginx
nobody 8 0.0 0.1 27328 3360 ? S 03:47 0:00 nginx: worker process
nobody 9 0.0 0.1 27328 3360 ? S 03:47 0:00 nginx: worker process
root 23 0.0 0.0 9092 660 pts/1 S+ 03:48 0:00 grep --color=auto nginx
测试下81端口能否被访问,镜像是否成功:
[root@aeec1bd1bd2b /]# exit
exit
[root@xavi ~]# curl 127.0.0.1:81
Welcome to nginx!