当前位置: 首页 > news >正文

Docker Compose 使用实例

文章目录

      • 一、Docker Compose 简介
      • 二、安装 Docker Compose
      • 三、基础配置文件示例(docker-compose.yml)
      • 四、关键配置解析
      • 五、常用命令
      • 六、完整项目示例(Node.js + MySQL + Nginx)
      • 七、高级功能
      • 八、最佳实践
      • 九、调试技巧

一、Docker Compose 简介

Docker Compose 是用于定义和运行多容器 Docker 应用程序的工具,通过 YAML 文件配置应用程序服务,一键启动所有关联容器。

二、安装 Docker Compose

  1. Linux
sudo curl -L "https://mirrors.tuna.tsinghua.edu.cn/docker/compose/releases/download/v2.32.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
  1. Windows/macOS
    通过 Docker Desktop 安装(已内置 Compose)

验证安装:

docker-compose --version

三、基础配置文件示例(docker-compose.yml)

version: '3.8'  # Compose文件格式版本services:web:build: .  # 使用当前目录的Dockerfile构建ports:- "8000:80"  # 主机端口:容器端口depends_on:- dbenvironment:- DB_HOST=dbnetworks:- mynetworkdb:image: mysql:8.0volumes:- db_data:/var/lib/mysqlenvironment:MYSQL_ROOT_PASSWORD: exampleMYSQL_DATABASE: myappnetworks:- mynetworkhealthcheck:test: ["CMD-SHELL", "mysqladmin ping -h localhost"]interval: 30stimeout: 10sretries: 3volumes:db_data:networks:mynetwork:driver: bridge

四、关键配置解析

  1. version:指定Compose文件格式版本(常用3.x)
  2. services:定义服务(容器)
    • build:指定构建上下文路径(含Dockerfile)
    • image:直接使用官方镜像
    • ports:端口映射
    • depends_on:服务依赖关系
    • environment:环境变量设置
  3. volumes:数据卷定义(持久化存储)
  4. networks:自定义网络配置
  5. healthcheck:容器健康检查

五、常用命令

  1. 启动服务
docker-compose up -d  # 后台启动
docker-compose up --build  # 重新构建后启动
  1. 停止服务
docker-compose down  # 停止并删除容器、网络等
docker-compose stop  # 仅停止容器
  1. 查看日志
docker-compose logs -f  # 实时查看日志
docker-compose logs web  # 查看指定服务日志
  1. 进入容器
docker-compose exec web bash  # 进入web容器
  1. 构建镜像
docker-compose build  # 构建所有服务镜像
docker-compose build web  # 仅构建web服务镜像

六、完整项目示例(Node.js + MySQL + Nginx)

  1. 项目结构
myapp/
├── docker-compose.yml
├── nginx/
│   ├── nginx.conf
│   └── Dockerfile
├── app/
│   ├── package.json
│   ├── server.js
│   └── Dockerfile
└── .env
  1. docker-compose.yml
version: '3.8'services:nginx:build: ./nginxports:- "80:80"depends_on:- appnetworks:- frontend- backendapp:build: ./appenvironment:- NODE_ENV=production- DB_HOST=dbnetworks:- backenddepends_on:db:condition: service_healthydb:image: mysql:8.0volumes:- db_data:/var/lib/mysqlenvironment:MYSQL_ROOT_PASSWORD_FILE: /run/secrets/db_root_passwordMYSQL_DATABASE: myappsecrets:- db_root_passwordnetworks:- backendhealthcheck:test: ["CMD-SHELL", "mysqladmin ping -h localhost"]interval: 30stimeout: 10sretries: 3volumes:db_data:networks:frontend:backend:secrets:db_root_password:file: .env
  1. app/Dockerfile
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm install --production
COPY . .
CMD ["npm", "start"]
  1. nginx/Dockerfile
FROM nginx:alpine
COPY nginx.conf /etc/nginx/conf.d/default.conf
  1. nginx/nginx.conf
server {listen 80;location / {proxy_pass http://app:3000;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;}
}
  1. .env
DB_ROOT_PASSWORD=supersecret

七、高级功能

  1. 扩展配置
# 扩展服务实例
app:deploy:replicas: 3resources:limits:cpus: '0.5'memory: 512M
  1. 多环境配置
# docker-compose.override.yml(开发环境)
version: '3.8'
services:app:build: ./appvolumes:- ./app:/app  # 挂载代码目录实现热更新environment:- NODE_ENV=development
  1. 使用模板文件
# docker-compose.yml
services:app:image: myapp:${TAG}

八、最佳实践

  1. 使用.env文件管理敏感信息
  2. 为不同环境创建独立的Compose文件(如docker-compose.prod.yml)
  3. 使用健康检查确保服务启动顺序
  4. 对持久化数据使用命名卷
  5. 定期清理未使用的镜像和卷:
docker system prune -a

九、调试技巧

  1. 查看容器状态:
docker-compose ps
  1. 检查网络配置:
docker network inspect mynetwork
  1. 验证配置文件:
docker-compose config

相关文章:

  • 接口测试流程和步骤
  • vue3 + element-plus中el-dialog对话框滚动条回到顶部
  • vue使用语音识别
  • 包管理工具有哪些?主流软件分享
  • Windows部署FunASR实时语音听写便捷部署教程
  • 详解LibTorch中train()函数
  • [渗透测试]渗透测试靶场docker搭建 — —全集
  • FreeRTos学习记录--2.内存管理
  • 自注意力机制、多头自注意力机制、填充掩码 Python实现
  • Vue如何获取Dom
  • 第5章:MCP框架详解
  • 【LeetCode 热题 100】哈希、双指针、滑动窗口
  • 大模型数据味蕾论
  • 《AI大模型应知应会100篇》第31篇:大模型重塑教育:从智能助教到学习革命的实践探索
  • 在线查看【免费】 mp3,wav,mp4,flv 等音视频格式文件文件格式网站
  • 离线安装rabbitmq全流程
  • 零基础上手Python数据分析 (20):Seaborn 统计数据可视化 - 轻松绘制精美统计图表!
  • 多源异构网络安全数据(CAPEC、CPE、CVE、CVSS、CWE)的作用、数据内容及其相互联系的详细分析
  • 5565反射内存网络产品
  • 【NVIDIA】Isaac Sim 4.5.0 加载 Franka 机械臂
  • 内部敏感文件遭万人共享,特朗普政府又曝安全漏洞
  • 姜仁华任中国水稻研究所所长,胡培松院士卸任
  • 工信部:加快推进6G技术研发等,前瞻布局和培育面向6G的应用产业生态
  • 北京将严查大数据杀熟和强制搭售等五种网络销售违法行为
  • 瑞士工业巨头ABB拟分拆机器人业务独立上市,市场份额全球第二