尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Docker容器化实践:从开发到生产的完整流程

Docker容器化实践:从开发到生产的完整流程
📅 发布时间:2026/6/20 1:44:49

前言

"在我电脑上能跑啊!"这句话曾经是我们团队的口头禅。环境不一致导致的问题层出不穷,直到我们引入了Docker。

这篇文章分享我们的Docker实践经验。


一、为什么选择Docker?

1.1 传统部署的痛点

bash

# 开发环境 Python 3.8 + MySQL 5.7 + Redis 5.0 # 测试环境 Python 3.9 + MySQL 8.0 + Redis 6.0 # 生产环境 Python 3.7 + MySQL 5.6 + Redis 4.0

问题:环境不一致导致各种诡异的Bug。

1.2 Docker的优势

  • 环境一致性:开发、测试、生产完全一致
  • 快速部署:秒级启动应用
  • 资源隔离:互不影响
  • 版本管理:镜像可追溯

二、编写Dockerfile

2.1 Python应用示例

dockerfile

# 使用官方Python基础镜像 FROM python:3.9-slim # 设置工作目录 WORKDIR /app # 复制依赖文件 COPY requirements.txt . # 安装依赖 RUN pip install --no-cache-dir -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple # 复制应用代码 COPY . . # 暴露端口 EXPOSE 8000 # 启动命令 CMD ["python", "app.py"]

2.2 构建镜像

bash

# 构建镜像 docker build -t myapp:v1.0 . # 查看镜像 docker images # 运行容器 docker run -d -p 8000:8000 --name myapp myapp:v1.0


三、Docker Compose:多容器编排

3.1 问题:手动启动多个容器太麻烦

bash

# 启动MySQL docker run -d --name mysql -e MYSQL_ROOT_PASSWORD=password mysql:8.0 # 启动Redis docker run -d --name redis redis:6.0 # 启动应用 docker run -d --name app --link mysql --link redis myapp:v1.0

3.2 使用Docker Compose

yaml

# docker-compose.yml version: '3.8' services: # MySQL数据库 mysql: image: mysql:8.0 environment: MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: mydb volumes: - mysql_data:/var/lib/mysql ports: - "3306:3306" healthcheck: test: ["CMD", "mysqladmin", "ping", "-h", "localhost"] interval: 10s timeout: 5s retries: 3 # Redis缓存 redis: image: redis:6.0 ports: - "6379:6379" volumes: - redis_data:/data # 应用服务 app: build: . ports: - "8000:8000" depends_on: mysql: condition: service_healthy redis: condition: service_started environment: DATABASE_URL: mysql://root:password@mysql:3306/mydb REDIS_URL: redis://redis:6379 volumes: - ./logs:/app/logs volumes: mysql_data: redis_data:

3.3 一键启动

bash

# 启动所有服务 docker-compose up -d # 查看日志 docker-compose logs -f app # 停止所有服务 docker-compose down


四、优化镜像大小

4.1 多阶段构建

dockerfile

# 第一阶段:构建 FROM node:16 AS builder WORKDIR /app COPY package*.json ./ RUN npm install COPY . . RUN npm run build # 第二阶段:运行 FROM nginx:alpine COPY --from=builder /app/dist /usr/share/nginx/html EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]

结果:

  • 原始镜像:1.2GB
  • 优化后:23MB

4.2 使用.dockerignore

# .dockerignore node_modules .git .env *.log .DS_Store

五、生产环境部署

5.1 使用环境变量

yaml

# docker-compose.prod.yml version: '3.8' services: app: image: myapp:v1.0 environment: - NODE_ENV=production - DATABASE_URL=${DATABASE_URL} - REDIS_URL=${REDIS_URL} - SECRET_KEY=${SECRET_KEY} restart: always logging: driver: "json-file" options: max-size: "10m" max-file: "3"

5.2 健康检查

dockerfile

Copy code

HEALTHCHECK --interval=30s --timeout=3s --start-period=40s --retries=3 \ CMD curl -f http://localhost:8000/health || exit 1

5.3 资源限制

yaml

services: app: image: myapp:v1.0 deploy: resources: limits: cpus: '0.5' memory: 512M reservations: cpus: '0.25' memory: 256M


六、日志和监控

6.1 集中日志管理

yaml

Copy code

services: app: logging: driver: "syslog" options: syslog-address: "tcp://logs.example.com:514" tag: "myapp"

6.2 监控容器状态

bash

# 查看容器资源使用 docker stats # 查看容器日志 docker logs -f myapp # 进入容器调试 docker exec -it myapp /bin/bash


七、CI/CD集成

7.1 GitLab CI配置

yaml

# .gitlab-ci.yml stages: - build - test - deploy build: stage: build script: - docker build -t myapp:$CI_COMMIT_SHA . - docker tag myapp:$CI_COMMIT_SHA myapp:latest - docker push myapp:$CI_COMMIT_SHA test: stage: test script: - docker run myapp:$CI_COMMIT_SHA pytest deploy: stage: deploy script: - docker-compose -f docker-compose.prod.yml pull - docker-compose -f docker-compose.prod.yml up -d only: - main


八、跨国团队协作

在我们的国际化团队中,Docker配置文件和部署文档需要支持多语言。我们使用同言翻译(Transync AI)来实时翻译跨语言在线会议,确保全球团队成员都能准确理解部署流程。


九、常见问题

问题1:容器内时区不对

dockerfile

# 设置时区 ENV TZ=Asia/Shanghai RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

问题2:容器数据丢失

yaml

# 使用数据卷持久化 volumes: - ./data:/app/data

问题3:网络连接问题

bash

# 创建自定义网络 docker network create mynetwork # 容器加入网络 docker run --network mynetwork myapp


十、性能对比

指标传统部署Docker部署提升
部署时间30分钟2分钟-93%
环境一致性60%100%+67%
启动时间5分钟5秒-98%
资源利用率30%70%+133%

十一、最佳实践

  1. 单一职责:一个容器只运行一个进程
  2. 最小化镜像:使用alpine等精简基础镜像
  3. 环境变量:敏感信息不要硬编码
  4. 健康检查:确保容器正常运行
  5. 日志管理:集中收集和分析日志
  6. 定期更新:及时更新基础镜像

十二、工具推荐

  • Docker Desktop:本地开发环境
  • Portainer:可视化容器管理
  • Watchtower:自动更新容器
  • Dive:分析镜像层
  • ctop:实时监控容器

十三、结语

Docker彻底改变了我们的开发和部署流程。从"在我电脑上能跑"到"在任何地方都能跑",这不仅是技术的进步,更是效率的飞跃。

如果你还没有使用Docker,现在就是最好的时机。欢迎在评论区分享你的Docker经验!

相关新闻

  • 模型推理 单多轮推理,gpu推理,lora推理和vllm(附代码示例)
  • 为什么Anthropic说:AI的未来是Skills不是Agent?
  • AXI-A7.4.10 Support for Atomic transactions(1)

最新新闻

  • 2026年6月,如何精准联系并选择知名的西安拓展夏令营? - 品牌鉴赏官2026
  • SQLi-Labs靶场从零搭建到通关全攻略(一):环境搭建与基础四关
  • AI搜索时代,深圳企业如何用“全意图GEO”抢占7亿用户的第一推荐位? - GEO优化
  • Page Assist终极指南:让本地AI模型成为你的网页浏览智能伴侣
  • 2026滨州漏水检测维修精选优质服务商TOP5推荐!卫生间漏水/厨房漏水/屋顶天花板漏水/阳台漏水/地下室漏水防水补漏检测维修-正规防水补漏公司优选口碑榜测评推荐 - 即刻修防水
  • Windows系统文件msvcp100d.dll丢失找不到问题解决

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号