如何使用docker compose部署服务

开发 开发工具
Docker有三个主要的作用:Build,Ship和Run,使用docker compose我们可以在Run的层面解决很多实际问题。本文通过发布3个APP(App1,App2,App3),来演示Docker在服务发布、网络、共享分区以及信息隔离与连通方面的工作。

谈到微服务的话题,技术上我们往往会涉及到多服务、多容器的部署与管理。

Docker 有三个主要的作用:Build, Ship和Run。使用docker compose我们可以在Run的层面解决很多实际问题,如:通过创建compose(基于YUML语法)文件,在这个文件上面描述应用的架构,如使用什么镜像、数据卷、网络、绑定服务端口等等,然后再用一条命令就可以管理所有的服务(如启动、停止、重启、日志监控等等)。

本文通过发布3个APP(App1,App2,App3),来演示Docker在服务发布、网络、共享分区以及信息隔离与连通方面的工作:

1. 安装Compose:

  1. [root@docker ~]# curl -L "https://github.com/docker/compose/releases/download/1.9.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose 
  2. [root@docker ~]# docker-compose version 
  3. docker-compose version 1.9.0, build 2585387 
  4. docker-py version: 1.10.6 
  5. CPython version: 2.7.9 
  6. OpenSSL version: OpenSSL 1.0.1t  3 May 2016 

2. 服务物理框架

 服务物理框架

说明:

  • Container1和2共在一个network namespace(netName1)内,Container3独立network namespace(netName2)
  • Container1挂载了一个系统卷(/opt/conf)到/mnt
  • Container3挂载了一个系统卷(./app/web)到/usr/share/nginx/html
  • Container1,2,3 nginx监听端口分别为:8080,8081,8082

3. docker-compose.yml 内容

  1. [root@docker compose]# more docker-compose.yml  
  2. version: '2' 
  3. services: 
  4.   App1: 
  5.     image: nginx 
  6.     ports: 
  7.       - "8080:80" 
  8.     networks: 
  9.       - "netName1" 
  10.     volumes: 
  11.       - /opt/conf/:/mnt 
  12.   App2: 
  13.     image: nginx 
  14.     ports: 
  15.       - "8081:80" 
  16.     networks: 
  17.       - "netName1" 
  18.     volumes: 
  19.       - /opt/conf/:/mnt 
  20.   App3: 
  21.     image: nginx 
  22.     ports: 
  23.       - "8082:80" 
  24.     networks: 
  25.       - "netName2" 
  26. networks: 
  27.   netName1: 
  28.     driver: bridge 
  29.   netName2: 
  30.     driver: bridge 

4. 运行

  1. [root@docker compose]# docker-compose up 
  2. Creating network "compose_netName1" with driver "bridge" 
  3. Creating network "compose_netName2" with driver "bridge" 
  4. Creating volume "compose_vol1" with local driver 
  5. Creating compose_App2_1 
  6. Creating compose_App1_1 
  7. Creating compose_App3_1 

在后台运行:[root@docker compose]# docker-compose up -d

5. 查看容器运行状态

  1. [root@docker compose]# docker-compose ps 
  2.      Name              Command          State               Ports              
  3. ----------------------------------------------------------------------------- 
  4. compose_App1_1   nginx -g daemon off;   Up      443/tcp, 0.0.0.0:8080->80/tcp  
  5. compose_App2_1   nginx -g daemon off;   Up      443/tcp, 0.0.0.0:8081->80/tcp  
  6. compose_App3_1   nginx -g daemon off;   Up      443/tcp, 0.0.0.0:8082->80/tcp  

 其他命令:

  1. [root@docker compose]# docker-compose restart #重启所有容器 
  2. [root@docker compose]# docker-compose restart App1  #重启App1 
  3. [root@docker compose]# docker-compose stop #停止所有容器 
  4. [root@docker compose]# docker-compose stop App1  #停止App1 

6. 验证网络隔离:

a.到App1 ping App2

  1. [root@docker compose]# docker-compose exec App1 bash 
  2. root@dd01fa7315ae:/# ping App2 
  3. PING App2 (172.18.0.3): 56 data bytes 
  4. 64 bytes from 172.18.0.3: icmp_seq=0 ttl=64 time=0.059 ms 
  5. 64 bytes from 172.18.0.3: icmp_seq=1 ttl=64 time=0.108 ms 
  6. 64 bytes from 172.18.0.3: icmp_seq=2 ttl=64 time=0.062 ms 
  7. 64 bytes from 172.18.0.3: icmp_seq=3 ttl=64 time=0.062 ms 

成功ping通。

b.到App2 ping App1和App3

  1. [root@docker compose]# docker-compose exec App2 bash 
  2. root@1905b2a875e3:/# ping App1 
  3. PING App1 (172.18.0.2): 56 data bytes 
  4. 64 bytes from 172.18.0.2: icmp_seq=0 ttl=64 time=0.043 ms 
  5. 64 bytes from 172.18.0.2: icmp_seq=1 ttl=64 time=0.089 ms 
  6. 64 bytes from 172.18.0.2: icmp_seq=2 ttl=64 time=0.085 ms 

App2 to App3-成功。

  1. [root@docker compose]# docker-compose exec App3 bash 
  2. root@595f744e8634:/# ping App1 
  3. PING App1 (172.31.213.13): 56 data bytes 
  4. ....#App3 to App1失败 
  5. root@595f744e8634:/# ping App2 
  6. PING App2 (172.31.213.13): 56 data bytes 
  7. ....#App3 to App2失败 

7. 验证共享卷

a. 在host /opt/conf/ 目录下新建nginx.conf 文件

  1. [root@docker conf]# pwd 
  2. /opt/conf 
  3. [root@docker conf]# touch nginx.conf  

b. 登录到App1 和App2查看

  1. [root@docker compose]# docker-compose exec App1 bash 
  2. root@49d702fc8606:/# cd /mmt  
  3. root@49d702fc8606:/mnt# ls 
  4. nginx.conf#成功挂载 
  5. [root@docker compose]# docker-compose exec App2 bash 
  6. root@1d161428d4dd:/# cd /mnt 
  7. root@1d161428d4dd:/mnt# ls 
  8. nginx.conf#成功挂载 

c. 在App3中挂载文件到nginx

修改docker-compose.yml App3:

  1. App3: 
  2.     image: nginx 
  3.     volumes: 
  4.       - ./app/web/:/usr/share/nginx/html 
  5.     ports: 
  6.       - "8082:80" 
  7.     networks: 
  8.       - "netName2" 

在host ./app/web 中添加 app3.html

  1. [root@docker web]# app3.html 
  2. [root@docker web]# ls 
  3. app3.html 
  4. [root@docker web]# more app3.html  
  5. <!DOCTYPE html> 
  6. <html> 
  7.     <head> 
  8.          <meta charset="utf-8"> 
  9.          <title>Welcome to leonyan's home, this is app3</title> 
  10.      </head> 
  11.    <body> 
  12.    Welcome to leonyan's home, this is app3! 
  13.    </body> 
  14. </html> 
  15.  
  16. [root@docker compose]# cd app/web/ 

访问App3 nginx:

访问App3 nginx

【本文为51CTO专栏作者“王森丰”的原创稿件,转载请注明出处】

戳这里,看该作者更多好文

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2023-09-08 08:14:14

2019-09-17 08:00:24

DockerCompose命令

2023-09-26 07:34:24

Docker部署依赖包

2019-07-01 09:33:58

DockerNginx操作系统

2022-07-29 15:19:27

Dockersudo权限

2023-10-10 00:09:14

2024-03-26 00:00:01

2019-07-29 08:00:18

文件容器Docker Comp

2015-08-03 16:15:53

Docker部署集群

2020-08-28 13:27:25

Docker Node应用

2024-01-17 08:01:28

Docker语法命令

2023-04-06 07:18:14

2023-11-02 08:45:07

2023-11-27 00:18:38

2023-05-14 23:30:38

PrestoHadoop函数

2023-08-08 10:23:34

2023-11-13 09:03:10

2023-10-17 14:29:35

2018-03-09 10:07:34

mysql

2014-12-15 11:23:00

Docker Comp分布式应用容器应用
点赞
收藏

51CTO技术栈公众号