1 用docker compose部署服务

- 需求:假如现在我们手里有很多容器,每个容器对应每个服务,有nginx容器,redis容器,mysql容器等。现在我们需要批量化的去管理,批量启动,停止,重启等操作!当然你会说用shell,可是如何不用shell来完成需求呢,那就需要用到接下来介绍的docker compose了。

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

- 安装compose

[root@chy ~]#  curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose //从官方下载一个最新的compose
[root@chy ~]# chmod 755 /usr/local/bin/docker-compose //将权限设置为755
[root@chy ~]# docker-compose version
docker-compose version 1.17.0-rc1, build a0f95af
docker-py version: 2.5.1
CPython version: 2.7.13
OpenSSL version: OpenSSL 1.0.1t  3 May 2016

Compose区分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。
Version 2支持更多的指令。Version 1没有声明版本默认是"version 1"。Version 1将来会被弃用。

定义一个docker compose 管理器

[root@chy ~]# docker ps //查看容器的名称,后面会用到
CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                  NAMES
f98ab40c32a6        centos              "bash"                   10 seconds ago       Up 4 seconds                               heuristic_torvalds
c06361830af1        centos7_1           "/bin/sh -c '/usr/..."   About a minute ago   Up About a minute   0.0.0.0:8080->80/tcp   root_app1_1
726da06d12c8        centos7_1           "tail -f /etc/passwd"    21 minutes ago       Up 20 minutes       80/tcp                 root_app2_1
1101ab2618a4        centos7_1           "/bin/sh -c '/usr/..."   18 hours ago         Up 18 hours         0.0.0.0:81->80/tcp     hopeful_pasteur
[root@chy ~]# vim docker-compose.yml
version: "2"
services:
  app1:
    p_w_picpath: centos_nginx
    ports:
      - "8080:80"
    networks:
      - "net1"
    volumes:
      - /data/:/data
  app2:
    p_w_picpath: centos_with_nettool
    networks:
      - "net2"
    volumes:
      - /data/:/data1
    entrypoint: tail -f /etc/passwd
networks:
  net1:
    driver: bridge
  net2:
    driver: bridge
参数详解:
version: "2" //版本为2版本
services: //相关容器或者镜像操作
  app1: //app1对应的是容器1的信息,这里需要注意是要运行的容器的名称
    p_w_picpath: centos7_1 ///p_w_picpaths的名字
    ports: //映射端口
      - "8080:80" //映射宿主机8080对应容器的80端口
    networks: //网络(默认是bridge模式)
      - "net1" //下面定义的net1(要是需要pipwork怎么办?官方不支持,就只能在写shell然后在 driver后面 定义none)
    volumes: //-v的参数指定
      - /data/:/data  //目录映射
  app2:
    p_w_picpath: centos
    networks:
      - "net2"
    volumes:
      - /data/:/data1
    entrypoint: tail -f /etc/passwd ///还是老问题BUG 为了不让执行后关闭,我们使用这条命令
networks: //这里就是如上net1定义的网络模式
  net1:
    driver: bridge
  net2:
    driver: bridge
[root@chy ~]# docker-compose up -d 
Recreating root_app2_1 ... 
Recreating root_app2_1
Recreating root_app2_1 ... done
[root@chy ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                  NAMES
9646c0a40ae1        centos              "tail -f /etc/passwd"    7 minutes ago       Up 7 minutes                               root_app2_1
f98ab40c32a6        centos              "bash"                   8 minutes ago       Up 7 minutes                               heuristic_torvalds
c06361830af1        centos7_1           "/bin/sh -c '/usr/..."   9 minutes ago       Up 9 minutes        0.0.0.0:8080->80/tcp   root_app1_1
1101ab2618a4        centos7_1           "/bin/sh -c '/usr/..."   18 hours ago        Up 18 hours         0.0.0.0:81->80/tcp     hopeful_pasteur
[root@chy ~]# docker-compose --help //有不会的指令及时查看命令帮助

希望看过的童鞋多多指教,谢谢!j_0063.gifj_0063.gif