利用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.rhkb.cn/news/462990.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Vue】一个案例带你学会组件通信!!!(1)(父传子props+子传父$emit)

嘿,开发者们👋!欢迎来到今天的Vue.js组件通信大冒险。你是否曾在父子组件间的数据同步问题上感到头疼?🤯 今天,我们将一起揭开Vue.js父子通信的神秘面纱,学习如何让数据在父子组件间流畅地“跳舞…

在VS中安装chatGPT

2、在VSCode中打开插件窗口 3、输入ChatGPT 4、这里有个ChatGPT中文版,就它了 5、安装 6、这时候侧边栏多了一个chatGPT分页图标,点击它 7、打个招呼 8、好像不行 9、看一下细节描述 10、根据要求按下按下快捷键 Ctrl Shift P 11、切换成国内模式 12、…

3. keil + vscode 进行stm32协同开发

1. 为什么使用vscode 主要还是界面友好,使用习惯问题,vscode 从前端,js, c/c, qt, 仓颉,rust都有很好插件的支持,并且有romote, wsl 等很多插件可以提高效率, 唯一的问题就是要使用插件进行环境…

PostgreSQL 学习笔记:PostgreSQL 主从复制

PostgreSQL 笔记:PostgreSQL 主从复制 博客地址:TMDOG 的博客 在现代应用程序中,数据库的高可用性和扩展性是至关重要的。PostgreSQL 提供了主从复制功能,可以在多个数据库实例之间复制数据,以实现冗余和负载均衡。本…

433、315通信、ev1527、2262编码

目录 ASK介绍EV1527编码芯片介绍模块介绍无线发射芯片无线接收芯片解码程序发射电路原理图 ASK介绍 ASK是幅移键控,通过调幅将数据发送出去,所以发送与接收都是多位二进制数。 ASK如何区分0和1? 0:发送 433.92Mhz 无线波形&…

Python 5个数据容器

列表(list) 特点:可以被修改 列表的定义 定义空列表: 变量名 [] 或 变量名 list() 定义变量: 变量名 [元素1,元素2,元素3,... ] 取出列表元素 列表名 [下标索引] 从前向…

复习数据库(约束)上篇

目录 约束的分类 分类 注意 主键约束 添加主键约束 1 建表时,添加 1.1创建表:定义列时指定 1.2 创建表:定义列之后独立指定主键: 2 建表后使用alter 关键字添加 删除约束 在主键添加自动增长属性 疑问 1 建表时添加 …

国内短剧源码短剧系统搭建小程序部署H5、APP打造短剧平台

​在当今的互联网时代,短剧作为一种新兴的娱乐形式,受到了越来越多用户的喜爱。为了提供更好的用户体验和满足用户需求,一个好的短剧系统需要具备多元化的功能和优质的界面设计。 本文将介绍国内短剧源码短剧系统搭建小程序部署H5、APP所需的…

Python(数据结构2)

常见数据结构 队列 队列(Queue),它是一种运算受限的线性表,先进先出(FIFO First In First Out) Python标准库中的queue模块提供了多种队列实现,包括普通队列、双端队列、优先队列等。 1 普通队列 queue.Queue 是 Python 标准库 queue 模块中的一个类…

QT 机器视觉 (3. 虚拟相机SDK、测试工具)

本专栏从实际需求场景出发详细还原、分别介绍大型工业化场景、专业实验室场景、自动化生产线场景、各种视觉检测物体场景介绍本专栏应用场景 更适合涉及到视觉相关工作者、包括但不限于一线操作人员、现场实施人员、项目相关维护人员,希望了解2D、3D相机视觉相关操作…

QT打包Macosx应用发布App Store简易流程

1、QC里编译工程,生成Release版的的app文件; 2、运行macdeployqt把需要的文件打包进app文件中; % ~/Qt/5.15.0/clang_64/bin/macdeployqt {编译的app文件所在路径}/Release/xxxx.app 3、使用codesign对app进行签名,如果要发App…

Android平台RTSP转RTMP推送之采集麦克风音频转发

技术背景 RTSP转RTMP推送,好多开发者第一想到的是采用ffmpeg命令行的形式,如果对ffmpeg比较熟,而且产品不要额外的定制和更高阶的要求,未尝不可,如果对产品稳定性、时延、断网重连等有更高的技术诉求,比较…

网络:ARP的具体过程和ARP欺骗

个人主页 : 个人主页 个人专栏 : 《数据结构》 《C语言》《C》《Linux》《网络》 《redis学习笔记》 文章目录 前言ARP具体过程ARP欺骗原理总结 前言 本文仅作为ARP具体过程和ARP欺骗的知识总结 硬件类型 :指定发送和接受ARP包的硬件类型&am…

单链表OJ题(3):合并两个有序链表、链表分割、链表的回文结构

目录 一、合并两个有序链表 二、链表分割 三、链表的回文结构 u解题的总体思路: 合并两个有序链表:首先创建新链表的头节点(哨兵位:本质上是占位子),为了减少一些判断情况,简化操作。然后我们…

整理 【 DBeaver 数据库管理工具 】的一些基础使用

目录 连接设置切换工作空间SQL编辑器(写sql语句)打开方式新建查询(sql编辑器)打开写的 sql 查询(项目浏览器) 备份sql文件查看历史执行语句自动保存sql语句的文件(编辑器)关闭自动生…

Android Studio 依赖仓库地址

在Android Studio进行开发时,会遇到依赖库下载慢或者老项目使用的依赖库找不到的问题,折腾了两天,终于找到解决方法,使用 阿里云云效Maven,地址:仓库服务https://developer.aliyun.com/mvn/guide &#xff…

51单片机教程(五)- LED灯闪烁

1 项目分析 让输入/输出口的P1.0或P1.0~P1.7连接的LED灯闪烁。 2 技术准备 1、C语言知识点 1 运算符 1 算术运算符 #include <stdio.h>int main(){// 算术运算符int a 13;int b 6;printf("%d\n", ab); printf("%d\n", a-b); printf("%…

MySQL日志——针对实习面试

目录 MySQL日志MySQL有哪些日志&#xff1f;请解释一下MySQL的二进制日志&#xff08;Binlog&#xff09;的作用&#xff1f;复制&#xff08;Replication&#xff09;数据恢复&#xff08;Point-in-Time Recovery&#xff09; Binlog日志的三种格式是什么&#xff1f;如何使用…

STM32 HAL库 SPI驱动1.3寸 OLED屏幕

目录 参考硬件引脚与接线 点亮屏幕CubeMX 配置OLED 驱动程序代码 参考 基于STM32F103C8T6最小系统板HAL库CubeMX SPI驱动7针 OLED显示屏&#xff08;0.96寸 1.3寸通用&#xff09;0.96 oled HAL库驱动 SPI STM32SPI驱动0.96/1.3寸 OLED屏幕&#xff0c;易修改为DMA控制STM32驱…

qt QStatusBar详解

1、概述 QStatusBar是Qt框架提供的一个小部件&#xff0c;用于在应用程序窗口底部显示状态信息。它可以显示一些固定的文本和图标&#xff0c;并且可以通过API动态更新显示内容。QStatusBar通常是一个水平的窗口部件&#xff0c;能够显示多行文本内容&#xff0c;非常适合用于…