Dockerfile,docker-compose部署服务

dockerfile格式

  1. FROM //指定基于哪个基础镜像
    格式 FROM 或者 FROM :, 比如
    FROM centos
    FROM centos:latest
  2. MAINTAINER //指定作者信息
    格式 MAINTAIN ,比如
    MAINTAINER aming [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 <conf/vhosts> </usr/local/nginx/conf>
  8. COPY
    格式同add
    使用方法和add一样,不同的是,它不支持url
  9. ENTRYPOINT 格式类似CMD
    容器启动时要执行的命令,它和CMD很像,也是只有一条生效,如果写多个只有最后一条有效。和CMD不同是:
    CMD 是可以被 docker run 指令覆盖的,而ENTRYPOINT不能覆盖。比如,容器名字为aming
    我们在Dockerfile中指定如下CMD:
    CMD ["/bin/echo", “test”]
    启动容器的命令是 docker run aming 这样会输出 test
    假如启动容器的命令是 docker run -it aming /bin/bash 什么都不会输出
    ENTRYPOINT不会被覆盖,而且会比CMD或者docker run指定的命令要靠前执行
    ENTRYPOINT [“echo”, “test”]
    docker run -it aming 123
    则会输出 test 123 ,这相当于要执行命令 echo test 123
  10. VOLUME
    格式 VOLUME ["/data"]
    创建一个可以从本地主机或其他容器挂载的挂载点。
  11. USER
    格式 USER daemon
    指定运行容器的用户
  12. WORKDIR
    格式 WORKDIR /path/to/workdir
    为后续的RUN、CMD或者ENTRYPOINT指定工作目录

dockerfile示例

编辑dockerfile文件:

[root@shuai-02 ~]# vim Dockerfile
## Set the base image to CentOS
FROM centos
# File Author / Maintainer
MAINTAINER aming [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

建立一个镜像

[root@shuai-01 ~]# docker build -t centos_nginx .

[root@shuai-01 ~]# docker images
REPOSITORY                     TAG                 IMAGE ID            CREATED             SIZE
centos_nginx                   latest              79812395edd3        13 seconds ago      369MB

通过这个镜像运行一个容器:

[root@shuai-01 ~]# docker run -itd -p 81:80 centos_nginx bash
ddd050405c037d8e7447ceaf344c9016e4088214ca1bcd5ef063369f0c3a2eae
[root@shuai-01 ~]# docker exec -it ddd050405 bash
[root@ddd050405c03 /]# ps aux |grep nginx
root          1  0.1  0.1  11684  1348 pts/0    Ss+  12:20   0:00 /bin/sh -c /usr/local/nginx/sbin/nginx && tail -f /etc/passwd bash
root          7  0.0  0.0  24884   788 ?        Ss   12:20   0:00 nginx: master process /usr/local/nginx/sbin/nginx
nobody        9  0.0  0.3  27328  3356 ?        S    12:20   0:00 nginx: worker process

docker compose 部署服务

docker compose可以方便我们快捷高效地管理容器的启动、停止、重启等操作,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。

安装compose:

curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
[root@shuai-01 ~]# ls
123.txt    anaconda-ks.cfg              log
1.txt      awk                          logs
1.txt.bak  centos-6-x86-minimal.tar.gz  pipework
2.txt      centos7_with_nettools.tar    sh
2.txt.bak  deng                         shell
3.txt      docker-compose-Linux-x86_64  shuai
4.txt      Dockerfile                   temp
aaa.txt    grep

修改一下权限:

[root@shuai-01 ~]# chmod 755 docker-compose-Linux-x86_64

编写docker-compose.yml

[root@shuai-01 ~]# vim docker-compose.yml

version: "2"
services:
  app1:
    image: centos_nginx
    ports:
      - "8080:80"
    networks:
      - "net1"
    volumes:
      - /data/:/data
  app2:
    image: centos-with-net
    networks:
      - "net2"
    volumes:
      - /data/:/data1
    entrypoint: tail -f /etc/passwd
networks:
  net1:
    driver: bridge
  net2:
    driver: bridge

启动:

[root@shuai-01 ~]# docker-compose up -d
Creating network "root_net2" with driver "bridge"
Creating network "root_net1" with driver "bridge"
Creating root_app2_1 ... 
Creating root_app1_1 ... 
Creating root_app2_1
Creating root_app2_1 ... done
[root@shuai-01 ~]# docker-compose ps
   Name                 Command             State          Ports        
------------------------------------------------------------------------
root_app1_1   /bin/sh -c /usr/local/ngin    Up      0.0.0.0:8080->80/tcp
              ...                                                       
root_app2_1   tail -f /etc/passwd           Up      

查看docker-compose支持指令:

[root@shuai-01 ~]# docker-compose --help

猜你喜欢

转载自blog.csdn.net/aoli_shuai/article/details/82973577