系统架构之微服务架构

微服务架构

  • 一.传统的单体架构与微服务架构的区别
    • [1.1 单体架构](#1.1 单体架构)
      • [1.1.1 优点](#1.1.1 优点)
      • [1.1.2 缺点](#1.1.2 缺点)
    • [1.2 微服务架构](#1.2 微服务架构)
      • [1.2.1 优点](#1.2.1 优点)
      • [1.2.2 面临的问题与挑战](#1.2.2 面临的问题与挑战)
  • [二. 微服务架构模式方案](#二. 微服务架构模式方案)
    • [2.1 聚合器微服务](#2.1 聚合器微服务)
    • [2.2 链式微服务](#2.2 链式微服务)
    • [2.3 数据共享微服务](#2.3 数据共享微服务)
    • [2.4 异步消息传递微服务](#2.4 异步消息传递微服务)
  • [三. SOA与微服务的区别](#三. SOA与微服务的区别)

微服务:顾名思义就是很小的服务,所以它是面向服务架构的一种。传统的单体架构与微服务架构的区别类似于雕版印刷VS活字印刷。

一.传统的单体架构与微服务架构的区别

1.1 单体架构

1.1.1 优点

①开发简单,集中式管理

②基本不会重复开发

③功能都在本地,没有分布式的管理和调用消耗

1.1.2 缺点

1、效率低:开发都在同一个项目改代码,相互等待,冲突不断

2、维护难:代码功能耦合在一起,新人不知道何从下手

3、不灵活:构建时间长,任何小修改都要重构整个项目,耗时

4、稳定性差:一个微小的问题,都可能导致整个应用挂掉

5、扩展性不够:无法满足高并发下的业务需求

1.2 微服务架构

目的:有效的拆分应用,实现敏捷开发和部署

1.2.1 优点

复杂应用解耦

小服务(且专注于做一件事),化整为零,易于小团队开发。

独立性强

独立开发、独立部署、独立测试、独立运行(每个服务在其独立进程中)

技术选型灵活

支持异构(如:每个服务使用不同的数据库)

容错能力强

故障被隔离在单个服务中,通过重试、平稳退化等机制实现应用层容错。

松耦合、易扩展

可根据需求独立扩展。

1.2.2 面临的问题与挑战

  • 分布式环境下的数据一致性

  • 测试的复杂性【服务间依赖测试】

  • 运维的复杂性

二. 微服务架构模式方案

2.1 聚合器微服务

2.2 链式微服务

2.3 数据共享微服务

2.4 异步消息传递微服务

三. SOA与微服务的区别

微服务 SOA
能拆分的就拆分 是整体的,服务能放一起的都放一起
纵向业务划分 是水平分多层
由单一组织负责 按层级划分不同部门的组织负责
细粒度 粗粒度
两句话可以解释明白 几百字只相当于SOA的目录
独立的子公司 类似大公司里面划分了一些业务单元(BU)
组件小 存在较复杂的组件
业务逻辑存在于每一个服务中 业务逻辑横跨多个业务领域
使用轻量级的通信方式,如HTTP 企业服务总线(ESB)充当了服务之间通信的角色
相关推荐
@insist12320 分钟前
网络工程师-信道容量计算与 PCM 编码:数据通信核心原理及软考考点解析
网络·网络工程师·pcm·软考·软件水平考试
TechWayfarer3 小时前
高并发场景下的IP归属地查询架构:从20ms到0.5ms的优化实践
网络协议·tcp/ip·架构
薛定谔的悦3 小时前
站控显示下级从控EMS的版本信息开发
架构
AI枫林晚3 小时前
源码解析Claude Code 项目 queryLoop 运行机制分析
人工智能·架构
架构师沉默4 小时前
为什么一个视频能让全国人民同时秒开?
java·后端·架构
CoovallyAIHub4 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
CoovallyAIHub4 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
带娃的IT创业者6 小时前
WeClaw_38_CFTA异步调用链优化:从阻塞15秒到非阻塞并发
性能优化·系统架构·异步编程·事件总线·事件驱动·并发优化·cfta
AI服务老曹7 小时前
源码级解耦与低代码集成:企业级 AI 视频中台的二次开发架构实践
人工智能·低代码·架构
郝学胜-神的一滴7 小时前
Qt6 + OpenGL 3.3 渲染环境搭建全指南:从空白窗口到专属渲染画布的优雅实现
数据结构·c++·线性代数·算法·系统架构·图形渲染