docker-compose常見的參數(shù)命令詳解
1. Docker Compose 產(chǎn)生背景
Compose 項目是 Docker 官方的開源項目,負(fù)責(zé)實現(xiàn)對 Docker 容器集群的快速編排。使用Dockerfile我們很容易定義一個單獨的應(yīng)用容器。然而在日常開發(fā)工作中,經(jīng)常會碰到需要多個容器相互配合來完成某項任務(wù)的情況。例如要實現(xiàn)一個 Web 項目,除了 Web 服務(wù)容器本身,往往還需要再加上后端的多種數(shù)據(jù)庫服務(wù)容器;再比如在分布式應(yīng)用一般包含若干個服務(wù),每個服務(wù)一般都會部署多個實例。如果每個服務(wù)都要手動啟停,那么效率之低、維護(hù)量之大可想而知。這時候就需要一個工具能夠管理一組相關(guān)聯(lián)的的應(yīng)用容器,這就是Docker Compose。
中文文檔:https://yeasy.gitbook.io/docker_practice/compose
2. Docker Compose模板文件
模板文件是使用 Compose 的核心,涉及到的指令關(guān)鍵字也比較多。下面主要列出幾個常見&重要的模板指令,其他指令大家可以自行百度。
默認(rèn)的模板文件名稱為 docker-compose.yml,格式為 YAML 格式。
1.environment
設(shè)置環(huán)境變量,主要是用來配置容器中程序所需要配置的一些參數(shù)。你可以使用數(shù)組或字典兩種格式。
services:
mysql:
image: mysql:latest
ports:
- 3307:3306
environment: # 使用字典格式,類似于 docker run -e MYSQL_ROOT_PASSWORD=root
MYSQL_ROOT_PASSWORD: root
也可以使用數(shù)組格式:
services:
mysql:
image: mysql:latest
ports:
- 3307:3306
environment: # 使用數(shù)組格式
- MYSQL_ROOT_PASSWORD=root
2.volumes
數(shù)據(jù)卷所掛載路徑設(shè)置,掛載數(shù)據(jù)卷的默認(rèn)權(quán)限是讀寫(rw)。
你可以在主機上掛載絕對路徑,或者掛載相對路徑,相對路徑是相對于當(dāng)前正在使用的compose配置文件的目錄進(jìn)行擴展。 相對路徑應(yīng)始終以 . 或者 … 開始。
services:
mysql:
image: mysql:latest
ports:
- 3307:3306
environment: # 使用字典格式,類似于 docker run -e MYSQL_ROOT_PASSWORD=root
MYSQL_ROOT_PASSWORD: root
volumes:
# 掛載絕對路徑映射,沒有這個路徑的話會自動創(chuàng)建
- /root/docker/composetest/tomcat/app_data:/var/lib/mysql
# 或者使用相對路徑映射,也會自動創(chuàng)建
- ./app_data:/var/lib/mysql
你還可以使用別名的方式掛載容器數(shù)據(jù)卷(可以跨多個服務(wù)并重用掛載卷,當(dāng)然使掛載絕對路徑或相對路徑也可以重用掛載卷),但要注意一點,使用別名的方式掛載需要在頂級volumes關(guān)鍵字中聲明掛在卷,否則啟動會報錯。
services:
mysql:
image: mysql:latest
ports:
- 3307:3306
environment:
MYSQL_ROOT_PASSWORD: root
volumes:
- my_app_data:/var/lib/mysql
web1:
volumes: # 重用my_app_data
- my_app_data:/var/lib/mysql
web2:
volumes: # 重用my_app_data
- my_app_data:/var/lib/mysql
volumes:
my_app_data:
3.build
指定 Dockerfile 所在文件夾的路徑(可以是絕對路徑,或者相對 docker-compose.yml 文件的路徑)。 Compose 將會利用它自動構(gòu)建這個鏡像,然后使用這個鏡像。
services:
webapp:
build: ./ # 從當(dāng)前目錄下尋找Dockerfile文件
你也可以使用 context 指令指定 Dockerfile 所在文件夾的路徑,使用 dockerfile 指令指定 Dockerfile 文件名,可以使用 args 指令指定構(gòu)建鏡像時往Dockerfile中傳入的變量。
services:
webapp:
build:
context: ./dir
dockerfile: Dockerfile_flask
args:
buildno: 1
4.depends_on
解決容器的依賴、啟動先后的問題。以下例子中會先啟動 redis db 再啟動 web。
注意:web 服務(wù)不會等待 redis、db 完全啟動之后才啟動。
services:
webapp:
build: .
depends_on:
- db
- redis
redis:
image: redis:latest
db:
image: mysql:latest
5.env_file
從文件中獲取環(huán)境變量,可以為單獨的文件路徑或列表。
services:
mysql:
image: mysql:latest
ports:
- 3307:3306
env_file: .env # 僅使用單個env文件
env_file: # 通過數(shù)組來使用多個env文件
- ./common.env
- ./apps/web.env
- /opt/secrets.env
環(huán)境變量文件中每一行必須符合格式,支持 # 開頭的注釋行。
# common.env: Set development environment MYSQL_ROOT_PASSWORD=root
6.networks
配置容器連接的網(wǎng)絡(luò)。
services:
webapp:
networks:
- flask-net
networks: # 在頂級networks關(guān)鍵字中需要聲明,才會在啟動時自動創(chuàng)建該網(wǎng)絡(luò),否則報錯。
flask-net:
7.ports
暴露端口信息。使用宿主端口:容器端口 (HOST:CONTAINER) 格式。
ports: 2. "80:80" # 綁定容器的80端口到主機的80端口 3. "9000:8080" # 綁定容器的8080端口到主機的9000端口 4. "443" # 綁定容器的443端口到主機的任意端口,容器啟動時隨機分配綁定的主機端口號
8.expose
暴露端口,但不映射到宿主機,只被連接的服務(wù)訪問。
和ports的區(qū)別是,expose暴露容器給link到當(dāng)前容器的容器,不會將端口暴露給主機。
9.restart
指定docker容器(服務(wù))總是運行。
services:
webapp:
networks:
- flask-net
restart: always
3. docker-compose指令
中文文檔: https://yeasy.gitbook.io/docker_practice/compose/commands
1.up -d(后臺啟動)
該命令十分強大,它將嘗試自動完成包括構(gòu)建鏡像,(重新)創(chuàng)建服務(wù),啟動服務(wù),并關(guān)聯(lián)服務(wù)相關(guān)容器的一系列操作。
docker-compose up -d · # 不寫服務(wù)名,默認(rèn)啟動docker-compose.yml所有服務(wù)
docker-compose up -d 服務(wù)名 # 啟動docker-compose.yml的對應(yīng)服務(wù)
默認(rèn)情況,如果服務(wù)容器已經(jīng)存在,docker-compose up 將會嘗試停止容器,然后重新創(chuàng)建(保持使用 volumes-from 掛載的卷),以保證新啟動的服務(wù)匹配 docker-compose.yml 文件的最新內(nèi)容。但是不會更新已經(jīng)打好的鏡像,如果鏡像錯誤,不能通過 docker-compose up 更新鏡像,只能先刪除鏡像。如果用戶不希望容器被停止并重新創(chuàng)建,可以使用 docker-compose up --no-recreate。這樣將只會啟動處于停止?fàn)顟B(tài)的容器,而忽略已經(jīng)運行的服務(wù)。如果用戶只想重新部署某個服務(wù),可以使用 docker-compose up --no-deps -d <SERVICE_NAME> 來重新創(chuàng)建服務(wù)并后臺停止舊服務(wù),啟動新服務(wù),并不會影響到其所依賴的服務(wù)。
2.down
此命令將會停止 up 命令所啟動的容器,并移除網(wǎng)絡(luò),但是不會移除已經(jīng)打好的鏡像。
docker-compose down · # 不寫服務(wù)名,默認(rèn)停止docker-compose.yml所有服務(wù)
docker-compose down 服務(wù)名 # 停止docker-compose.yml的對應(yīng)服務(wù)
3.exec
進(jìn)入指定的容器。和docker的exec命令一樣。
docker-compose exec 服務(wù)名 bash
4.ps
列出項目中目前的所有容器。
docker-compose ps # 列出所有運行的服務(wù)
docker-compose ps -q # 只列出容器的ID信息
選項:
-q 只打印容器的 ID 信息。
5.top
查看所有服務(wù)容器內(nèi)運行的進(jìn)程,或者查看指定服務(wù)名的容器內(nèi)運行的進(jìn)程。
docker-compose top
docker-compose top 服務(wù)名
6.logs -f(實時)
查看所有服務(wù)容器,或指定服務(wù)容器的日志輸出。默認(rèn)情況下,docker-compose 將對不同的服務(wù)輸出使用不同的顏色來區(qū)分??梢酝ㄟ^ --no-color 來關(guān)閉顏色。該命令在調(diào)試問題的時候十分有用。
docker-compose logs # 輸出所有服務(wù)容器的日志
docker-compose logs 服務(wù)名 # 輸出對應(yīng)服務(wù)的日志
docker-compose logs -f 服務(wù)名 # 實時輸出對應(yīng)服務(wù)的日志
其他命令參考中文文檔手冊。
總結(jié)
到此這篇關(guān)于docker-compose常見的參數(shù)命令詳解的文章就介紹到這了,更多相關(guān)docker-compose參數(shù)命令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker安裝MySQL及授權(quán)遠(yuǎn)程訪問的詳細(xì)教程
Docker是一種流行的容器化平臺,可以簡化應(yīng)用程序的部署和管理,下面這篇文章主要給大家介紹了關(guān)于Docker安裝MySQL及授權(quán)遠(yuǎn)程訪問的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05
docker?搭建?vulhub?靶場環(huán)境的詳細(xì)過程
Vulhub是一個基于docker和docker-compose的漏洞環(huán)境集合,進(jìn)入對應(yīng)目錄并執(zhí)行一條語句即可啟動一個全新的漏洞環(huán)境,讓漏洞復(fù)現(xiàn)變得更加簡單,讓安全研究者更加專注于漏洞原理本身,這篇文章給大家介紹docker?搭建?vulhub?靶場環(huán)境的過程,感興趣的朋友一起看看吧2022-08-08
docker安裝Portainer CE的實現(xiàn)示例
Portainer是一款易用的開源容器管理工具,適合各級經(jīng)驗的Docker用戶,它提供直觀的UI,方便管理、部署和監(jiān)控容器,本文就來介紹一下docker安裝Portainer CE的實現(xiàn)示例,感興趣的可以了解一下2024-09-09
docker: invalid reference format.問題
這篇文章主要介紹了docker: invalid reference format.問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01

