Docker compose

持续集成
  • 持续集成, 简称CI(continuous integration).
  • CI做为敏捷开发重要的一步,其目的在于让产品快速迭代的同时,尽量保持高质量.
  • CI一种能够增长项目可见性,下降项目失败风险的开发实践。其每一次代码更新,都要经过自动化测试来检测代码和功能的正确性,只有经过自动测试的代码才能进行后续的交付和部署.
  • CI 是团队成员间(产研测)更好地协调工做,更好的适应敏捷迭代开发,自动完成减小人工干预,保证每一个时间点上团队成员提交的代码都能成功集成的,能够很好的用于对Android/iOS项目的打包.

流程结构
简单绘制了下Jenkins的一个流程,以下图:
IBM也有一个看似更复杂一点的图,以下图
持续交互流程图:
 

由此能够看出, 持续集成有一个关键步骤就是 RUN BVT automation, 而这一步骤的实现须要有一个完整的,干净的bvt 环境来支撑。 没有一个好的bvt环境, run bvt automation 就没有意义。 如何生成一个完整,干净的bvt 环境呢,这里咱们能够引入Docker compose. Docker compose 是 Docker 容器进行编排的工具,定义和运行多容器的应用,能够一条命令启动多个容器。使用docker compose咱们能够在Run的层面解决不少实际问题,如:经过建立compose(基于YUML语法)文件,在这个文件上面描述应用的架构,如使用什么镜像、数据卷、网络、绑定服务端口等等,而后再用一条命令就能够管理全部的服务(如启动、中止、重启、日志监控等等)。html

 

使用Compose 基本上分为三步:nginx

  1. Dockerfile 定义应用的运行环境
  2. docker-compose.yml 定义组成应用的各服务
  3. docker-compose up 启动整个应用
  本文经过发布3个APP(App1,App2,App3),来演示Docker在服务发布、网络、共享分区以及信息隔离与连通方面的工做: 1.安装Compose:
  • [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 [root@docker ~]# docker-compose version docker-compose version 1.9.0, build 2585387 docker-py version: 1.10.6 CPython version: 2.7.9 OpenSSL version: OpenSSL 1.0.1t 3 May 2016

     

2.服务物理框架
这里写图片描述git

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

3.docker-compose.yml 内容web

[root@docker compose]# more docker-compose.yml version: '2' services: App1: image: nginx ports: - "8080:80" networks: - "netName1" volumes: - /opt/conf/:/mnt App2: image: nginx ports: - "8081:80" networks: - "netName1" volumes: - /opt/conf/:/mnt App3: image: nginx ports: - "8082:80" networks: - "netName2" networks: netName1: driver: bridge netName2: driver: bridge

 

4.运行docker

[root@docker compose]# docker-compose up
Creating network "compose_netName1" with driver "bridge" Creating network "compose_netName2" with driver "bridge" Creating volume "compose_vol1" with local driver Creating compose_App2_1 Creating compose_App1_1 Creating compose_App3_1

 

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

5.查看容器运行状态bash

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

其余命令:网络

[root@docker compose]# docker-compose restart #重启全部容器
[root@docker compose]# docker-compose restart App1 #重启App1 [root@docker compose]# docker-compose stop #中止全部容器 [root@docker compose]# docker-compose stop App1 #中止App1

 

6.验证网络隔离:
a.到App1 ping App2架构

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

成功ping通
b.到App2 ping App1和App3app

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

 

App2 to App3-成功

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

 

7.验证共享卷 a. 在host /opt/conf/ 目录下新建nginx.conf 文件

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

 

b.登陆到App1 和App2查看

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

 

c. 在App3中挂载文件到nginx
修改docker-compose.yml App3:

App3:
    image: nginx
    volumes:
      - ./app/web/:/usr/share/nginx/html ports: - "8082:80" networks: - "netName2"

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

[root@docker web]# app3.html
[root@docker web]# ls app3.html [root@docker web]# more app3.html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Welcome to leonyan's home, this is app3</title> </head> <body> Welcome to leonyan's home, this is app3! </body> </html> [root@docker compose]# cd app/web/

访问App3 nginx:
这里写图片描述

相关文章
相关标签/搜索