從上一節課咱們瞭解到可使用一個Dockerfile模板文件來快速構建一個本身的鏡像並運行爲應用容器。可是在平時工做的時候,咱們會碰到多個容器要互相配合來使用的狀況,好比數據庫加上我們Web應用等等。這種狀況下,每次都要一個一個啓動容器設置命令變得麻煩起來,因此Docker Compose誕生了。java
Compose的做用是「定義和運行多個Docker容器的應用」。使用Compose,你能夠在一個配置文件(yaml格式)中配置你應用的服務,而後使用一個命令,便可建立並啓動配置中引用的全部服務。python
Compose中兩個重要概念:mysql
服務 (service):一個應用的容器,實際上能夠包括若干運行相同鏡像的容器實例。git
項目 (project):由一組關聯的應用容器組成的一個完整業務單元,在 docker-compose.yml文件中定義。github
Compose支持三平臺Windows、Mac、Linux,安裝方式各有不一樣。我這裏使用的是Linux系統,其餘系統安裝方法web
能夠參考官方文檔和開源GitHub連接:redis
Docker Compose官方文檔連接:https://docs.docker.com/composesql
Docker Compose GitHub連接:https://github.com/docker/composedocker
Linux上有兩種安裝方法,Compose項目是用Python寫的,可使用Python-pip安裝,也能夠經過GitHub下載二進制文件進行安裝。數據庫
經過Python-pip安裝
1.安裝Python-pip
yum install -y epel-release yum install -y python-pip
2.安裝docker-compose
pip install docker-compose
3.驗證是否安裝
docker-compose version
4.卸載
pip uninstall docker-compose
經過GitHub連接下載安裝
非ROOT用戶記得加sudo
1.經過GitHub獲取下載連接,以往版本地址:https://github.com/docker/compose/releases
curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname-s)-$(uname -m)" -o /usr/local/bin/docker-compose
2.給二進制下載文件可執行的權限
chmod +x /usr/local/bin/docker-compose
3.可能沒有啓動程序,設置軟鏈接,好比:
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
4.驗證是否安裝
docker-compose version
5.卸載
若是是二進制包方式安裝的,刪除二進制文件便可。
rm /usr/local/bin/docker-compose
簡單實例
Compose的使用很是簡單,只須要編寫一個docker-compose.yml,而後使用docker-compose 命令操做便可。
docker-compose.yml描述了容器的配置,而docker-compose 命令描述了對容器的操做
1.咱們使用一個微服務項目先來作一個簡單的例子,首先建立一個compose的工做目錄,而後建立一個eureka文件夾,裏面放可執行jar包和編寫一個Dockerfile文件,目錄結構以下:
compose eureka Dockerfile eureka-server-2.0.2.RELEASE.jar
2.在compose目錄建立模板文件docker-compose.yml文件並寫入如下內容
version: '1' services: eureka: build: ./eureka ports: - 3000:3000 expose: - 3000
指定鏡像名稱或者鏡像id,若是該鏡像在本地不存在,Compose會嘗試pull下來。
示例:
image: java:8
指定Dockerfile文件的路徑。能夠是一個路徑,例如:build: ./dir
也能夠是一個對象,用以指定Dockerfile和參數,例如:
build: context: ./dir dockerfile: Dockerfile-alternate args: buildno: 1
覆蓋容器啓動後默認執行的命令。
示例:
command: bundle exec thin -p 3000
也能夠是一個list,相似於Dockerfile總的CMD指令,格式以下:
command: [bundle, exec, thin, -p, 3000]
連接到其餘服務中的容器。能夠指定服務名稱和連接的別名使用SERVICE:ALIAS 的形式,或者只指定服務名稱,示
例:
web: links: - db - db:database – redis
表示連接到docker-compose.yml外部的容器,甚至並不是Compose管理的容器,特別是對於那些提供共享容器或共同
服務。格式跟links相似,示例:
external_links: - redis_1 - project_db_1:mysql - project_db_1:postgresql
暴露端口信息。使用宿主端口:容器端口的格式,或者僅僅指定容器的端口(此時宿主機將會隨機指定端口),相似於docker run -p ,示例:
ports: "3000" "3000-3005" "8000:8000" "9090-9091:8080-8081" "49100:22" "127.0.0.1:8001:8001" "127.0.0.1:5000-5010:5000-5010"
暴露端口,只將端口暴露給鏈接的服務,而不暴露給宿主機,示例:
expose: - "3000" - "8000"
卷掛載路徑設置。能夠設置宿主機路徑 (HOST:CONTAINER) 或加上訪問模式 (HOST:CONTAINER:ro)。示例:
volumes:
Just specify a path and let the Engine create a volume
Specify an absolute path mapping
Path on the host, relative to the Compose file
User-relative path
Named volums
從另外一個服務或者容器掛載卷。能夠指定只讀或者可讀寫,若是訪問模式沒有指定,則默認是可讀寫。示例:
volumes_from:
service_name
service_name:ro
container:container_name
container:container_name:rw
設置環境變量。可使用數組或者字典兩種方式。只有一個key的環境變量能夠在運行Compose的機器上找到對應的
值,這有助於加密的或者特殊主機的值。示例:
environment: RACK_ENV: development SHOW: 'true' SESSION_SECRET: environment: - RACK_ENV=development - SHOW=true - SESSION_SECRET
從文件中獲取環境變量,能夠爲單獨的文件路徑或列表。若是經過 docker-compose -f FILE 指定了模板文件,則env_file 中路徑會基於模板文件路徑。若是有變量名稱與 environment 指令衝突,則以envirment 爲準。示例:
env_file: .env env_file: - ./common.env - ./apps/web.env - /opt/secrets.env
繼承另外一個服務,基於已有的服務進行擴展。
設置網絡模式。示例:
net: "bridge" net: "host" net: "none" net: "container:[service name or container name/id]"
配置dns服務器。能夠是一個值,也能夠是一個列表。示例:
dns: 8.8.8.8 dns: - 8.8.8.8 - 9.9.9.9
配置DNS的搜索域,能夠是一個值,也能夠是一個列表,示例:
dns_search: example.com dns_search: - dc1.example.com - dc2.example.com
docker-compose.yml 還有不少其餘命令,能夠參考docker-compose.yml文件官方文檔:
https://docs.docker.com/compose/compose-file/
使用docker-compose一次性來編排三個微服務:eureka服務(eureka-server-2.0.2.RELEASE.jar)、user服務(user-2.0.2.RELEASE.jar)、power服務(power-2.0.2.RELEASE.jar)
1.建立一個工做目錄和docker-compose模板文件
2.工做目錄下建立三個文件夾eureka、user、power,並分別構建好三個服務的鏡像文件
以eureka的Dockerfile爲例:
# 基礎鏡像 FROM java:8 # 做者 MAINTAINER user01 # 把可執行jar包複製到基礎鏡像的根目錄下 ADD eureka-server-2.0.2.RELEASE.jar /eureka-server-2.0.2.RELEASE.jar # 鏡像要暴露的端口,如要使用端口,在執行docker run命令時使用-p生效 EXPOSE 3000 # 在鏡像運行爲容器後執行的命令 ENTRYPOINT ["java","-jar","/eureka-server-2.0.2.RELEASE.jar"]
目錄文件結構:
compose docker-compose.yml eureka Dockerfile eureka-server-2.0.2.RELEASE.jar user Dockerfile user-2.0.2.RELEASE.jar power Dockerfile power-2.0.2.RELEASE.jar
3.編寫docker-compose模板文件:
version: '1' services: eureka: image: eureka:v1 ports: - 8080:8080 user: image: user:v1 ports: - 8081:8081 power: image: power:v1 ports: - 8082:8082
4.啓動微服務,能夠加上參數-d後臺啓動
docker-compose up -d