25.17 用docker compose部署服務html
25.18 docker compose示例python
25.17 用docker compose部署服務mysql
好比咱們用dockerfile作了一些鏡像,這些景象有nginx的,有mysql的,有redis的,如今要把這三個鏡像,讓他們同時啓動批量的管理。我要跑一個服務,就可能要docker run 第一個,docker run第二個等等,可是這樣很繁瑣。固然能夠寫一個腳本,而這個docker compose就相似與shell腳本,他能夠批量的管理幾個容器linux
就像jumpserver,那新版的jumpserver用到了一個高版本的python,他的環境不是很好部署,因此他就藉助於docker,自動的把這個環境部署好。也及時說,把jumpserver放到有docker的服務器上,他就能夠運行了,只不過咱們跑的是一個docker容器,他用到的就是composenginx
docker compose能夠方便咱們快捷高效地管理容器的啓動、中止、重啓等操做,它相似於linux下的shell腳本,基於yaml語法,在該文件裏咱們能夠描述應用的架構,好比用什麼鏡像、數據卷、網絡模式、監聽端口等信息。咱們能夠在一個compose文件中定義一個多容器的應用(好比jumpserver),而後經過該compose來啓動這個應用。git
安裝compose方法以下github
1.curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-composeweb
#就是去官方下載最新版本的docker composeredis
2.chmod 755 !$sql
3.docker-compose version 查看版本信息
Compose區分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1沒有聲明版本默認是"version 1"。Version 1未來會被棄用。
#從compose1.6.0之後就是Version2版本了。在compose編寫的配置文件裏,格式叫作yaml語法,在這裏面若是不聲明,就用的version1,聲明瞭就用version2
實例:
[root@axinlinux-01 ~]# curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 617 0 617 0 0 313 0 --:--:-- 0:00:01 --:--:-- 313
100 8649k 100 8649k 0 0 212k 0 0:00:40 0:00:40 --:--:-- 271k
[root@axinlinux-01 ~]# du -sh /usr/local/bin/docker-compose #下好的在這個路徑裏。也能夠du -sh !$看一下
8.5M /usr/local/bin/docker-compose
[root@axinlinux-01 ~]# chmod 755 /usr/local/bin/docker-compose
[root@axinlinux-01 ~]# 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
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
25.18 docker compose示例
1.vim docker-compose.yml //內容到https://coding.net/u/aminglinux/p/yuanke_centos7/git/blob/master/25docker/docker-compose.yml 查看
docker-compose up -d 能夠啓動兩個容器
docker-compose --help
docker-compose ps/down/stop/start/rm
關於docker-compose語法的參考文檔 http://www.web3.xin/index/article/182.html
實例:
version: "2" #使用2版本
services: #接下來的操做是容器或者是鏡像的操做。第一級目錄
app1: #第二級目錄。容器的名字(app1)
image: centos_nginx #對應的鏡像
ports: #就是-p,你要映射的哪一個端口
- "8080:80"
networks: #使用哪個網絡
- "net1" #net1從下面定義
volumes: #就是-v的那個選項(掛載)。本地的data:容器的data。若是不寫冒號只寫一個data,就至關於一個數據卷,把data作一個分享
- /data/:/data
app2: #第二個容器
image: centos_with_nettool #基於這個鏡像
networks:
- "net2" #固然也能夠寫成net1
volumes:
- /data/:/data1
entrypoint: tail -f /etc/passwd #寫這條是由於,docker run的時候後面爲bash的時候,容器是沒辦法繼續運行的。也就是你一旦運行了yaml的腳本以後,前面的容器能啓動可是後面的啓動不了。
能夠先把他註釋掉看看有什麼提示
networks:
net1:
driver: bridge #driver就是定義哪一種模式。其實不寫的話默認就是bridge。這樣寫的話能夠寫成其餘的模式。一般是bridge。需注意pipework不支持,須要的話只能寫腳本,這就寫none,而後再給他分配在一個ip就好了
net2:
driver: bridge
[root@axinlinux-01 ~]# docker-compose up -d #這樣啓動起來
Recreating root_app2_1 ...
root_app1_1 is up-to-date
Recreating root_app2_1 ... done
[root@axinlinux-01 ~]# docker ps #看一下,只啓動了app1.是由於咱們註釋了tail -f
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
a703ed9e8005 centos_nginx "/bin/sh -c '/usr/lo…" 2 minutes ago Up 2 minutes 0.0.0.0:8080->80/tcp root_app1_1
[root@axinlinux-01 ~]# docker ps -a #咱們找一下app2發現已經爲exited了
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
9486bcb736e0 centos_with_net "/bin/bash" 12 seconds ago Exited (0) 11 seconds ago root_app2_1
[root@axinlinux-01 ~]# docker-compose --help #能夠看到他的指令有哪些
[root@axinlinux-01 ~]# !vim #將tail -f註釋取消
vim docker-compose.yml
[root@axinlinux-01 ~]# docker-compose up -d #從新啓動