Docker?Compose從入門到實踐的完全指南
1. Docker Compose 簡介與核心價值
Docker Compose 是一個用于定義和運行多容器 Docker 應用程序的工具。通過一個 YAML 文件來配置應用的服務,只需簡單命令就能創(chuàng)建和啟動所有服務。
核心優(yōu)勢:
- 簡化多容器管理:通過單一文件管理多個關(guān)聯(lián)容器
- 開發(fā)環(huán)境標準化:團隊共享相同的環(huán)境配置
- 快速環(huán)境搭建:一條命令啟動復雜應用棧
- 服務依賴管理:自動處理服務間的依賴關(guān)系
- 配置即代碼:版本控制環(huán)境配置
典型應用場景:
- 開發(fā)環(huán)境搭建
- 自動化測試環(huán)境
- 單主機部署
- 微服務應用演示
2. Compose 文件結(jié)構(gòu)與版本
2.1 基本文件結(jié)構(gòu)
version: "3.8" # 指定Compose文件格式版本 services: # 容器服務定義 webapp: image: nginx:alpine ports: - "80:80" database: image: postgres:13 environment: POSTGRES_PASSWORD: example volumes: # 持久化卷定義 db-data:
版本選擇建議:
- 新項目使用 3.8+ 版本
- 需要 swarm 部署時使用 3.x 版本
- 舊系統(tǒng)兼容考慮 2.4 版本
2.2 版本演進對比
特性 | 2.x 系列 | 3.x 系列 |
---|---|---|
Swarm 模式支持 | 有限支持 | 完整支持 |
GPU 支持 | 不支持 | 3.7+ 支持 |
擴展字段 | 不支持 | 3.4+ 支持 |
服務依賴 | depends_on 基本 | 增強的健康檢查依賴 |
3. 核心服務配置詳解
3.1 鏡像與構(gòu)建
使用現(xiàn)有鏡像:
services: redis: image: redis:6.2-alpine
基于 Dockerfile 構(gòu)建:
services: webapp: build: context: ./dir dockerfile: Dockerfile.dev args: NODE_ENV: development image: my-webapp:1.0
參數(shù)說明:
- context:構(gòu)建上下文路徑
- dockerfile:指定 Dockerfile 文件名
- args:構(gòu)建時變量傳遞
3.2 端口映射
services: web: ports: - "80:80" # 主機端口:容器端口 - "443:443/tcp" # 指定協(xié)議 - "3000-3005:3000-3005" # 端口范圍 - "9090" # 僅暴露容器端口
最佳實踐:
- 開發(fā)環(huán)境使用明確端口映射
- 生產(chǎn)環(huán)境謹慎暴露端口
- 考慮使用反向代理管理入口
3.3 環(huán)境變量配置
.env 文件:
DB_USER=admin DB_PASS=secret
Compose 文件引用:
services: db: environment: POSTGRES_USER: ${DB_USER} POSTGRES_PASSWORD: ${DB_PASS} env_file: - ./db.env
優(yōu)先級規(guī)則:
- environment 顯式定義
- env_file 文件定義
- 容器內(nèi)已有環(huán)境變量
3.4 數(shù)據(jù)持久化
services: database: volumes: - db-data:/var/lib/postgresql/data - ./logs:/app/logs volumes: db-data: driver: local
掛載類型對比:
- 命名卷:docker 管理,適合生產(chǎn)數(shù)據(jù)
- 主機路徑:開發(fā)調(diào)試方便
- 臨時卷:內(nèi)存存儲,高性能臨時數(shù)據(jù)
4. 網(wǎng)絡(luò)配置策略
4.1 默認網(wǎng)絡(luò)行為
services: web: networks: - frontend api: networks: - frontend - backend networks: frontend: backend: driver: bridge
自動生成規(guī)則:
- 默認創(chuàng)建 項目名_default 網(wǎng)絡(luò)
- 相同網(wǎng)絡(luò)內(nèi)的服務可通過服務名互訪
- 隔離不同項目的網(wǎng)絡(luò)環(huán)境
4.2 自定義網(wǎng)絡(luò)配置
networks: app-net: driver: bridge ipam: config: - subnet: 172.20.0.0/24 gateway: 172.20.0.1 attachable: true
高級選項:
- internal: true 創(chuàng)建隔離網(wǎng)絡(luò)
- enable_ipv6: true 啟用 IPv6
- labels 添加元數(shù)據(jù)
5. 服務依賴與健康檢查
5.1 依賴控制
services: web: depends_on: db: condition: service_healthy redis: condition: service_started db: healthcheck: test: ["CMD-SHELL", "pg_isready -U postgres"] interval: 5s timeout: 3s retries: 5
依賴條件類型:
- service_started:服務容器啟動
- service_healthy:通過健康檢查
- service_completed_successfully:一次性任務成功
5.2 健康檢查配置
healthcheck: test: ["CMD", "curl", "-f", "http://localhost/health"] interval: 30s timeout: 10s retries: 3 start_period: 5s
檢查方式:
- CMD:直接執(zhí)行命令
- CMD-SHELL:通過 shell 執(zhí)行
- 禁用:disable: true
6. 常用命令實戰(zhàn)
6.1 基礎(chǔ)命令
# 啟動所有服務(后臺模式) docker-compose up -d # 查看運行狀態(tài) docker-compose ps # 停止服務 docker-compose stop # 停止并刪除容器 docker-compose down # 重建服務 docker-compose up -d --build
6.2 調(diào)試命令
# 查看服務日志 docker-compose logs -f web ???????# 執(zhí)行一次性命令 docker-compose run --rm web python manage.py migrate # 進入運行中容器 docker-compose exec db psql -U postgres
6.3 擴展操作
# 水平擴展服務實例 docker-compose up -d --scale web=3 # 查看服務資源使用 docker-compose top # 驗證配置文件 docker-compose config
7. 生產(chǎn)環(huán)境最佳實踐
7.1 安全配置
services: db: read_only: true tmpfs: /run security_opt: - no-new-privileges:true user: "1000:1000"
安全建議:
- 避免使用 root 用戶
- 限制內(nèi)存和 CPU
- 設(shè)置只讀文件系統(tǒng)
- 禁用特權(quán)升級
7.2 資源約束
services: worker: deploy: resources: limits: cpus: '0.5' memory: 512M reservations: memory: 256M restart_policy: condition: on-failure max_attempts: 3
關(guān)鍵配置:
- CPU 限制 (cpus)
- 內(nèi)存限制 (memory)
- 重啟策略
- 容器更新順序
7.3 多環(huán)境配置
base.yml:
services: app: image: my-app env_file: .env
override.yml:
services: app: environment: DEBUG: "true" ports: - "8080:80"
啟動命令:
docker-compose -f base.yml -f override.yml up
8. 完整示例分析
微服務應用示例
version: "3.8" services: frontend: build: ./frontend ports: - "3000:3000" depends_on: - api networks: - app-net api: build: ./backend environment: DB_URL: postgres://user:pass@db:5432/app volumes: - ./backend:/app networks: - app-net - db-net db: image: postgres:13 environment: POSTGRES_PASSWORD: pass POSTGRES_USER: user POSTGRES_DB: app volumes: - db-data:/var/lib/postgresql/data networks: - db-net healthcheck: test: ["CMD-SHELL", "pg_isready -U user -d app"] interval: 5s networks: app-net: db-net: internal: true volumes: db-data:
架構(gòu)特點:
- 前端服務暴露 3000 端口
- API 服務連接數(shù)據(jù)庫
- 數(shù)據(jù)庫使用獨立內(nèi)部網(wǎng)絡(luò)
- 數(shù)據(jù)持久化存儲
- 健康檢查確保依賴順序
9. 總結(jié)與進階建議
9.1 核心要點回顧
編排能力:Compose 簡化了多容器應用的管理
聲明式配置:YAML 文件定義完整應用棧
環(huán)境一致性:實現(xiàn)開發(fā)-測試-生產(chǎn)環(huán)境一致
資源控制:精確管理服務資源分配
服務發(fā)現(xiàn):內(nèi)置 DNS 解析簡化服務通信
9.2 進階學習建議
與 Swarm/K8s 集成:
docker stack deploy -c compose.yml myapp
使用擴展字段:
x-logging: &default-logging options: max-size: "10m" max-file: "3"
性能調(diào)優(yōu):
- 合理設(shè)置 ulimits
- 優(yōu)化卷驅(qū)動選擇
- 配置 OOM 殺手策略
監(jiān)控方案:
services: prometheus: image: prom/prometheus ports: - "9090:9090"
通過掌握 Docker Compose,您已經(jīng)具備了高效管理容器化應用的能力。建議從簡單項目開始實踐,逐步應用到復雜生產(chǎn)環(huán)境,最終實現(xiàn)基礎(chǔ)設(shè)施即代碼的現(xiàn)代化運維模式。
到此這篇關(guān)于Docker Compose從入門到實踐的完全指南的文章就介紹到這了,更多相關(guān)Docker Compose使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在docker環(huán)境中實現(xiàn)配置hosts
這篇文章主要介紹了在docker環(huán)境中實現(xiàn)配置hosts,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04使用docker compose搭建一個elk系統(tǒng)的方法
這篇文章主要介紹了使用docker-compose搭建一個elk系統(tǒng)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08

Docker?AIGC等大模型深度學習環(huán)境搭建步驟最新詳細版