【docker】docker compose多容器部署

embedded/2024/12/4 16:35:46/

Docker Compose 的详细讲解与实际应用

  1. 什么是 Docker Compose?
    Docker Compose 是一个工具,用于定义和运行多容器 Docker 应用。
    通过一个 docker-compose.yml 文件,可以同时启动多个服务,简化多容器管理。

  2. Docker Compose 的核心功能

    • 服务定义:通过 YAML 文件描述服务的构建和运行方式。
    • 网络通信:服务间自动创建网络通信,无需额外配置。
    • 依赖管理:可以定义服务间的启动顺序。
    • 多环境支持:通过 .env 文件实现环境变量管理。

实际应用场景:部署微服务应用
场景:一个应用有三个服务:

  1. web 服务:前端 Web 应用,使用 Nginx。
  2. app 服务:后端服务,使用 Python Flask。
  3. db 服务:数据库,使用 MySQL。

优化后的文件结构

myapp/
├── docker-compose.yml
├── app/
│   ├── Dockerfile
│   ├── app.py
│   └── requirements.txt
└── db/

docker-compose.yml 文件

version: '3.8'services:web:image: nginx:latestports:- "8080:80"networks:- myapp_networkapp:build:context: ./appdockerfile: Dockerfilenetworks:- myapp_networkdepends_on:- dbdb:image: mysql:5.7environment:MYSQL_ROOT_PASSWORD: rootpasswordMYSQL_DATABASE: myappnetworks:- myapp_networknetworks:myapp_network:driver: bridge

app/Dockerfile 文件

FROM python:3.9-slim
WORKDIR /app
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
COPY . .
CMD ["python", "app.py"]

app/requirements.txt 文件

flask
mysql-connector-python

app/app.py 文件

from flask import Flaskapp = Flask(__name__)@app.route('/')
def hello_world():return 'Hello, Docker Compose!'if __name__ == '__main__':app.run(host='0.0.0.0', port=5000)
  1. 操作步骤

  2. 应用网络配置

    • Docker Compose 默认为每个项目创建独立的网络,服务之间通过服务名称通信。
    • 例如:app 服务可以通过 db 直接访问数据库,无需额外配置 IP 地址。
  3. 扩展:多环境支持

    • 使用 .env 文件管理环境变量。
    • docker-compose.yml 中通过 ${VAR_NAME} 引用环境变量。
    • 示例 .env 文件:
      MYSQL_ROOT_PASSWORD=rootpassword
      MYSQL_DATABASE=myapp
      
    • 修改 docker-compose.yml
      environment:MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}MYSQL_DATABASE: ${MYSQL_DATABASE}
      
  4. 总结
    Docker Compose 简化了多容器应用的管理流程,通过 YAML 文件定义服务间依赖、网络和存储配置,适合开发、测试和生产环境。


http://www.ppmy.cn/embedded/142948.html

相关文章

FPGA实战篇(呼吸灯实验)

1.呼吸灯简介 呼吸灯采用 PWM 的方式,在固定的频率下,通过调整占空比的方式来控制 LED 灯亮度的变化。 PWM(Pulse Width Modulation ),即脉冲宽度调制,它利用微处理器输出的 PWM 信号,实现对…

web安全攻防入门教程

Web安全攻防入门教程 Web安全攻防是指在Web应用程序的开发、部署和运行过程中,保护Web应用免受攻击和恶意行为的技术与策略。这个领域不仅涉及防御措施的实现,还包括通过渗透测试、漏洞挖掘和模拟攻击来识别潜在的安全问题。 本教程将带你入门Web安全攻…

如何解决服务器扫描出的ASP木马问题

随着互联网的发展,网站安全问题日益凸显。其中,ASP(Active Server Pages)木马因其隐蔽性和危害性成为攻击者常用的手段之一。本文将详细介绍如何检测和清除服务器上的ASP木马,以保障网站的安全。 1. ASP木马概述 ASP…

详解日志格式配置:XML 与 Spring Boot 配置文件格式

详解日志格式配置:XML 与 Spring Boot 配置文件格式 日志是现代应用程序中不可或缺的一部分,通过定制化日志格式和颜色,开发人员可以更方便地调试和监控应用。本文将深入讲解如何在 XML 配置文件 和 Spring Boot 配置文件 中设置日志格式&am…

Python 入门教程(2)搭建环境 | 2.4、VSCode配置Node.js运行环境

文章目录 一、VSCode配置Node.js运行环境1、软件安装2、安装Node.js插件3、配置VSCode4、创建并运行Node.js文件5、调试Node.js代码 一、VSCode配置Node.js运行环境 1、软件安装 安装下面的软件: 安装Node.js:Node.js官网 下载Node.js安装包。建议选择L…

A058-基于Spring Boot的餐饮管理系统的设计与实现

🙊作者简介:在校研究生,拥有计算机专业的研究生开发团队,分享技术代码帮助学生学习,独立完成自己的网站项目。 代码可以查看项目链接获取⬇️,记得注明来意哦~🌹 赠送计算机毕业设计600个选题ex…

蓝队工具分享

RmEye RmEye是一个window上的基于att&ck现代EDR设计思想的威胁响应工具. 不同于EDR,它轻量、高效.自身定位是轻量级威胁检出工具. 而不是繁重的、需要付费的、效果不明的所谓的EDR 功能特点 基于att&ck设计.所有设计只是为了符合att&ck的攻击路径、攻击链(虽然规…

「Mac畅玩鸿蒙与硬件36」UI互动应用篇13 - 数字滚动抽奖器

本篇将带你实现一个简单的数字滚动抽奖器。用户点击按钮后,屏幕上的数字会以滚动动画的形式随机变动,最终显示一个抽奖数字。这个项目展示了如何结合定时器、状态管理和动画实现一个有趣的互动应用。 关键词 UI互动应用数字滚动动画效果状态管理用户交…