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

利用Docker Compose构建微服务架构

💓 博客主页:瑕疵的CSDN主页
📝 Gitee主页:瑕疵的gitee主页
⏩ 文章专栏:《热点资讯》

利用Docker Compose构建微服务架构

    • 引言
    • Docker Compose 简介
      • 安装 Docker Compose
      • 创建项目结构
      • 编写 Dockerfile
        • 前端 Dockerfile
        • 后端 Dockerfile
        • 数据库 Dockerfile
      • 编写 docker-compose.yml
      • 启动服务
      • 访问应用
      • 关闭服务
    • 微服务之间的通信
    • 环境变量
    • 总结

引言

随着互联网技术的发展,传统的单体应用已经无法满足现代业务的需求。为了提高系统的可伸缩性、灵活性以及维护性,越来越多的开发者开始转向微服务架构。Docker Compose 是 Docker 官方提供的工具,用于定义和运行多容器 Docker 应用程序。本文将介绍如何使用 Docker Compose 构建一个简单的微服务架构。

Docker Compose 简介

Docker Compose 允许你在一个 YAML 文件中定义多个容器及其依赖关系,然后通过一个命令启动所有服务。这大大简化了多服务应用的部署过程。

安装 Docker Compose

在使用 Docker Compose 之前,需要先安装 Docker。安装完成后,可以通过以下命令安装 Docker Compose:

sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

创建项目结构

假设我们要构建一个包含前端、后端和数据库的微服务架构。项目结构如下:

microservices/
├── frontend/
│   └── Dockerfile
├── backend/
│   ├── app.py
│   └── Dockerfile
├── db/
│   └── Dockerfile
└── docker-compose.yml

编写 Dockerfile

前端 Dockerfile
frontend 目录下创建 Dockerfile

FROM node:14WORKDIR /appCOPY package*.json ./
RUN npm install
COPY . .EXPOSE 3000
CMD ["npm", "start"]

后端 Dockerfile
backend 目录下创建 Dockerfile

FROM python:3.8-slimWORKDIR /appCOPY requirements.txt .
RUN pip install -r requirements.txt
COPY . .EXPOSE 5000
CMD ["python", "app.py"]

数据库 Dockerfile
db 目录下创建 Dockerfile

FROM postgres:13ENV POSTGRES_USER=myuser
ENV POSTGRES_PASSWORD=mypassword
ENV POSTGRES_DB=mydb

编写 docker-compose.yml

在项目根目录下创建 docker-compose.yml 文件:

version: '3'services:frontend:build: ./frontendports:- "3000:3000"depends_on:- backendbackend:build: ./backendports:- "5000:5000"depends_on:- dbdb:build: ./dbenvironment:POSTGRES_USER: myuserPOSTGRES_PASSWORD: mypasswordPOSTGRES_DB: mydb

启动服务

在项目根目录下运行以下命令启动所有服务:

docker-compose up

访问应用

打开浏览器,访问 http://localhost:3000,你应该能够看到前端应用。后端服务将在 http://localhost:5000 上运行。

关闭服务

要关闭所有服务,可以在终端中按 Ctrl+C,或者运行以下命令:

docker-compose down

微服务之间的通信

在微服务架构中,服务之间需要相互通信。Docker Compose 提供了一个内部网络,使得服务之间可以通过服务名进行通信。

例如,在后端服务中,可以通过以下方式连接到数据库:

import psycopg2conn = psycopg2.connect(host='db',port=5432,user='myuser',password='mypassword',dbname='mydb'
)

环境变量

在生产环境中,通常会使用环境变量来管理配置信息。Docker Compose 支持从 .env 文件中读取环境变量。

在项目根目录下创建 .env 文件:

POSTGRES_USER=myuser
POSTGRES_PASSWORD=mypassword
POSTGRES_DB=mydb

然后在 docker-compose.yml 中引用这些环境变量:

version: '3'services:frontend:build: ./frontendports:- "3000:3000"depends_on:- backendbackend:build: ./backendports:- "5000:5000"depends_on:- dbenvironment:- DATABASE_HOST=db- DATABASE_PORT=5432- DATABASE_USER=${POSTGRES_USER}- DATABASE_PASSWORD=${POSTGRES_PASSWORD}- DATABASE_NAME=${POSTGRES_DB}db:build: ./dbenvironment:POSTGRES_USER: ${POSTGRES_USER}POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}POSTGRES_DB: ${POSTGRES_DB}

总结

通过本文,你已经学会了如何使用 Docker Compose 构建一个简单的微服务架构。Docker Compose 的强大之处在于它能够简化多服务应用的部署过程,使得开发者可以更专注于业务逻辑的实现。
Docker Compose 项目结构图

Docker Compose 使得微服务架构的构建变得更加简单和高效。
Docker Compose 服务启动图

http://www.lryc.cn/news/477766.html

相关文章:

  • 数据中台一键大解析!
  • MySQL45讲 第十六讲 “order by”是怎么工作的?
  • 智慧商城项目-VUE2
  • 音视频入门基础:FLV专题(22)——FFmpeg源码中,获取FLV文件音频信息的实现(中)
  • Chrome与火狐哪个浏览器的性能表现更好
  • uniapp在js方法中,获取当前用户的uid(uni-id-user)表中的用户id
  • 影响神经网络速度的因素- FLOPs、MAC、并行度以及计算平台
  • 【万字详解】如何在微信小程序的 Taro 框架中设置静态图片 assets/image 的 Base64 转换上限值
  • 复合选择器,CSS特性,背景属性,显示模式(HTML)
  • 加密货币行业与2024年美国大选
  • Hive SQL中判断内容包含情况的全面指南
  • 匿名管道 Linux
  • 苍穹外卖WebSocket无法建立连接 (修改前端代码)
  • 音频内容理解
  • MQTT实用示例集:Air201版
  • Day23 opencv图像预处理
  • 优化模型训练过程中的显存使用率、GPU使用率
  • RocketMQ学习笔记
  • Linux第三讲:环境基础开发工具使用
  • 日本TikTok直播的未来:专线网络助力创作者突破极限
  • 如何在家庭网络中设置静态IP地址:一份实用指南
  • qt QFile详解
  • ESP8266 自定义固件烧录-Tcpsocket固件
  • 内网项目,maven本地仓库离线打包,解决Cannot access central in offline mode?
  • stack和queue --->容器适配器
  • ffmpeg视频解码
  • 前端入门一之CSS知识详解
  • 【JS学习】10. web API-BOM
  • C#实现递归获取所有父级的列表
  • 【深度学习】梯度累加和直接用大的batchsize有什么区别