设为首页 收藏本站
查看: 1225|回复: 0

[经验分享] Docker 配置安装Dockerfile

[复制链接]

尚未签到

发表于 2019-2-21 10:04:19 | 显示全部楼层 |阅读模式
  [toc]

Docker 配置安装Dockerfile

一、Dockerfile创建镜像 – Dockerfile格式

之前我们有说过创建镜像有多种模式:①通过容器创建镜像②使用模板创建镜像③Dockfile创建镜像
  最后一条也即是我们今天所要讲的,通过Dockfile来创建镜像。

1. FROM   //指定基于哪个基础镜像(docker images 所列出的images)

格式 FROM  或者  FROM :,  比如
FROM centos
FROM centos:latest
2. MAINTAINER  //指定作者信息(可有可无)

格式  MAINTAIN  ,比如
MAINTAINER  xavi  XXX@XXXX.com
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 XXX@xxxx.com
# 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 XXX@xxxx.com   //指定用户信息
# 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!

body {
width: 35em;
margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif;
}
扩展:

vim Dockerfile //内容如下
FROM centos:6
MAINTAINER Xavi
RUN yum install -y gcc gcc-c++ make openssl-devel pcre-devel
ADD nginx-1.12.1.tar.gz /tmp
RUN cd /tmp/nginx-1.12.1 && ./configure --prefix=/usr/local/nginx && make -j 2 && make install
RUN rm -f /usr/local/nginx/conf/nginx.conf
COPY nginx.conf /usr/local/nginx/conf
EXPOSE 80
CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-675199-1-1.html 上篇帖子: 容器技术|Docker三剑客之docker 下篇帖子: Docker Compose 部署服务
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表