1 用docker compose部署服务
- 需求:假如现在我们手里有很多容器,每个容器对应每个服务,有nginx容器,redis容器,mysql容器等。现在我们需要批量化的去管理,批量启动,停止,重启等操作!当然你会说用shell,可是如何不用shell来完成需求呢,那就需要用到接下来介绍的docker compose了。
- docker compose可以方便我们快捷高效地管理容器的启动、停止、重启等操作,它类似于linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像、数据卷、网络模式、监听端口等信息。我们可以在一个compose文件中定义一个多容器的应用(比如jumpserver),然后通过该compose来启动这个应用。
- 安装compose
1
2
3
4
5
6
7
8
9
10
|
[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 管理器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
[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:
image: centos_nginx
ports:
-
"8080:80"
networks:
-
"net1"
volumes:
-
/data/
:
/data
app2:
image: 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的信息,这里需要注意是要运行的容器的名称
image: centos7_1
///images
的名字
ports:
//
映射端口
-
"8080:80"
//
映射宿主机8080对应容器的80端口
networks:
//
网络(默认是bridge模式)
-
"net1"
//
下面定义的net1(要是需要pipwork怎么办?官方不支持,就只能在写shell然后在 driver后面 定义none)
volumes:
//-v
的参数指定
-
/data/
:
/data
//
目录映射
app2:
image: 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 //有不会的指令及时查看命令帮助
|
本文转自我不是瘦子51CTO博客,原文链接:http://blog.51cto.com/chy940405/1982876,如需转载请自行联系原作者