Spring 微服务解决了单体架构的哪些痛点?

news2025/4/21 15:21:42

1. 部署困难 (Deployment Difficulty & Risk)

  • 单体痛点:
    • 整体部署: 对单体应用的任何微小修改(哪怕只是一行代码),都需要重新构建、测试和部署整个庞大的应用程序。
    • 部署频率低: 由于部署过程复杂且风险高,发布周期通常很长(几周甚至几个月)。
    • 高风险: 一旦部署出现问题,可能会导致整个应用瘫痪,影响所有业务功能。回滚也同样复杂和耗时。
    • 部署窗口限制: 往往需要在业务低峰期(如深夜或周末)进行部署,限制了业务的快速迭代。
  • 微服务解决方案:
    • 独立部署: 每个微服务都是一个独立的部署单元。可以随时修改、测试和部署单个服务,而无需触动其他服务。
    • 高频部署: 显著缩短发布周期,可以实现每天甚至每天多次部署,更快地将新功能交付给用户。
    • 降低风险: 单个服务的部署失败只会影响该服务的功能范围(理想情况下)。可以更容易的进行金丝雀发布、蓝绿部署等低风险发布策略。
    • 无特定部署窗口: 可以更灵活的安排部署时间。

2. 技术栈陈旧与演进困难 (Outdated Technology Stack & Evolution Difficulty)

  • 单体痛点:
    • 技术锁定: 整个应用通常被锁定在一个技术栈(如特定的编程语言、框架、数据库)上。随着时间推移,这个技术栈可能会变得过时或不再是最优选择。
    • 升级困难: 对底层框架或库进行重大升级是一项艰巨且风险极高的任务,可能需要对整个代码库进行大量修改和回归测试。
    • 采用新技术成本高: 想要在单体应用中尝试或引入新的语言、数据库或框架非常困难,往往需要大规模重构。
    • 技术债务累积: 由于难以进行改造,技术债务会不断累积,进一步拖慢开发速度和增加维护成本。
  • 微服务解决方案:
    • 技术异构性 (Polyglot): 每个微服务都可以根据其具体需求选择最合适的技术栈。可以使用 Java 处理事务,用 Python 做数据分析,用 Node.js 处理高并发 IO 等。
    • 渐进式升级与替换: 可以更容易的对单个服务进行技术升级,甚至用新技术完全重写某个服务,而不会影响其他服务。
    • 拥抱创新: 在现有的微服务中可以尝试和应用最新的技术和模式。
    • 隔离技术债务: 技术债务可以被限制在单个服务内部,更容易管理和偿还。

3. 扩展性差 (Poor Scalability)

  • 单体痛点:
    • 整体扩展: 无法针对应用的不同部分进行差异化扩展。即使只有一小部分功能(如用户认证)成为性能瓶颈,也必须扩展整个应用程序的实例。
    • 资源浪费: 扩展整个应用意味着所有组件(即使是低负载的组件)都需要更多的资源(CPU、内存),导致资源利用率低下。
    • 受限于“短板”: 整个应用的扩展能力往往受限于其中最难扩展或资源需求最高的那个组件。
  • 微服务解决方案:
    • 独立扩展: 可以根据每个服务的实际负载和资源需求,独立的扩展或缩减其服务实例数量。
    • 资源优化: 可以为不同的服务选择不同配置的硬件或实例类型(如 CPU 密集型、内存密集型、IO 密集型),实现更精细化的资源管理和成本优化。
    • 更高的整体扩展性: 打破了单体应用中“短板”的限制,系统的整体扩展能力更强。

4. 团队协作效率低 (Low Team Collaboration Efficiency)

  • 单体痛点:
    • 代码库庞大: 所有开发人员都在同一个庞大、复杂的代码库上工作。
    • 熟知业务功能: 开发人员需要理解整个系统的很多部分才能进行有效的修改,上手难度大,新人培养周期长。
    • 开发瓶颈: 大量开发人员同时修改同一个代码库,容易产生代码冲突,需要频繁合并代码,降低开发效率。协调成本高。
    • 职责不清: 随着系统变大,模块之间的界限变得模糊,职责划分不清晰,容易出现互相推诿或重复造轮子的情况。
    • 决策缓慢: 对架构或重要组件的修改需要协调多个团队或大量人员,决策过程缓慢。
  • 微服务解决方案:
    • 小型、专注的代码库: 每个微服务的代码库相对较小,业务逻辑更聚焦。
    • 降低业务功能: 开发人员只需要深入理解他们负责的一到两个服务,更容易上手和维护。
    • 团队自治与并行开发 (Conway’s Law): 可以组建小型、跨职能的自治团队,每个团队负责一个或多个服务的完整生命周期(开发、测试、部署、运维)。团队之间可以并行开发,减少了协调和冲突。
    • 明确所有权: 每个服务有明确的归属团队,职责清晰。
    • 更快的决策: 团队可以在其负责的服务范围内更快的做出技术决策。

此外,微服务还能解决一些其他的单体痛点:

  • 可靠性/容错性差 (Poor Reliability/Fault Tolerance): 单体应用中一个模块的严重错误(如内存泄漏、死循环)可能导致整个应用崩溃。微服务通过故障隔离提高了系统的整体弹性,一个服务的失败不应导致整个系统不可用(需要配合熔断、降级等机制)。
  • 维护成本高 (High Maintenance Cost): 修改庞大、耦合度高的单体代码库非常耗时且风险高。微服务使得修改和维护的范围更小、更可控。

总之,采用微服务架构的主要目的就是通过分解复杂性,来解决单体应用在敏捷性、可扩展性、技术选型、容错性、团队效率等方面遇到的瓶颈和挑战,从而更好的支撑业务的快速发展和变化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2339514.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【1】云原生,kubernetes 与 Docker 的关系

Kubernetes?K8s? Kubernetes经常被写作K8s。其中的数字8替代了K和s中的8个字母——这一点倒是方便了发推,也方便了像我这样懒惰的人。 什么是云原生? 云原生: 它是一种构建和运行应用程序的方法,它包含&am…

Kubernetes控制平面组件:APIServer 限流机制详解

云原生学习路线导航页(持续更新中) kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计(一)Kubernetes架构原则和对象设计(二)Kubernetes架构原则和对象设计(三)Kubernetes控…

springboot全局异常捕获处理

一、需求 实际项目中,经常抛出各种异常,不能直接抛出异常给前端,这样用户体验相当不好,用户看不懂你的Exception,对于一些sql异常,直接抛到页面上也不安全。所以有没有好的办法解决这些问题呢,当然有了&am…

【文献阅读】EndoNet A Deep Architecture for Recognition Tasks on Laparoscopic Videos

关于数据集的整理 Cholec80 胆囊切除手术视频数据集介绍 https://zhuanlan.zhihu.com/p/700024359 数据集信息 Cholec80 数据集 是一个针对内窥镜引导 下的胆囊切除手术视频流程识别数据集。数据集提供了每段视频中总共7种手术动作及总共7种手术工具的标注,标…

基于springboot的个人财务管理系统的设计与实现

博主介绍:java高级开发,从事互联网行业六年,熟悉各种主流语言,精通java、python、php、爬虫、web开发,已经做了六年的毕业设计程序开发,开发过上千套毕业设计程序,没有什么华丽的语言&#xff0…

Linux系统编程---孤儿进程与僵尸进程

1、前言 在上一篇博客文章已经对Linux系统编程内容进行了较为详细的梳理,本文将在上一篇的基础上,继续梳理Linux系统编程中关于孤儿进程和僵尸进程的知识脉络。如有疑问的博客朋友可以通过下面的博文链接进行参考学习。 Linux系统编程---多进程-CSDN博客…

简单使用MCP

简单使用MCP 1 简介 模型上下文协议(Model Context Protocol,MCP)是由Anthropic(产品是Claude)推出的开放协议,它规范了应用程序如何向LLM提供上下文。MCP可帮助你在LLM之上构建代理和复杂的工作流。 从…

MySQL:9.表的内连和外连

9.表的内连和外连 表的连接分为内连和外连 9.1 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,之前查询都是内连 接,也是在开发过程中使用的最多的连接查询。 语法: select 字段 from 表1 inner join 表2 on 连接…

在阿里云和树莓派上编写一个守护进程程序

目录 一、阿里云邮件守护进程 1. 安装必要库 2. 创建邮件发送脚本 mail_daemon.py 3. 设置后台运行 二、树莓派串口守护进程 1. 启用树莓派串口 2. 安装依赖库 3. 创建串口输出脚本 serial_daemon.py 4. 设置开机自启 5. 使用串口助手接收 一、阿里云邮件守护进程 1.…

基于前端技术的QR码API开发实战:从原理到部署

前言 QR码(Quick Response Code)是一种二维码,于1994年开发。它能快速存储和识别数据,包含黑白方块图案,常用于扫描获取信息。QR码具有高容错性和快速读取的优点,广泛应用于广告、支付、物流等领域。通过扫…

RenderStage::drawInner

文章目录 RenderStage::drawInnerOSG渲染后台关系图OSG的渲染流程RenderBin::draw(renderInfo,previous)RenderBin::drawImplementationRenderLeaf::renderosg::State::apply(const StateSet*)Drawable::draw(RenderInfo& renderInfo)Drawable::drawInner(RenderInfo& …

C++初阶-类和对象(中)

目录 1.类的默认成员函数 2.构造函数(难度较高) ​编辑 ​编辑 ​编辑 3.析构函数 4.拷贝构造函数 5.赋值运算符重载 5.1运算符重载 5.2赋值运算符重载 6.取地址运算符重载 6.1const成员函数 6.2取地址运算符重载 7.总结 1.类的默认成员函数…

智谱开源新一代GLM模型,全面布局AI智能体生态

2024年4月15日,智谱在中关村论坛上正式发布了全球首个集深度研究与实际操作能力于一体的AI智能体——AutoGLM沉思。这一革命性技术的发布标志着智谱在AGI(通用人工智能)领域的又一次重要突破。智谱的最新模型不仅推动了AI智能体技术的升级&am…

分治-快排-75.颜色分类-力扣(LeetCode)

一、题目解析 给定一个数组将其元素按照0,1,,2三段式排序,并且在原地进行排序。 二、算法原理 解法:三指针 用cur遍历数组,left记录0的最左侧,right记录2的最右侧。 left初始值为-1,right的初…

铅酸电池充电器方案EG1253+EG4321

参考: 基于EG1253EG4321铅酸电池(48V20AH)三段式充电器 屹晶微高性价比的电瓶车充电器方案——EG1253 电瓶电压 48V电瓶锂电池,其充满约为55V~56V,因此充电器输出电压为55V~56V; 若是48V铅酸电池,标称电压为48V&…

vue 中formatter

:formatter 是前端表格组件(如 Element UI、Vxe-Table 等)中用于 ​​自定义单元格内容显示格式​​ 的属性。它的核心作用是:将后端返回的原始数据(如编码、状态值等)转换为更友好、更易读的文本。 这段代码 :forma…

协程?协程与线程的区别?Java是否支持协程?

一、前言 协程(Coroutine) 是一种轻量级的并发编程模型,允许在单线程内通过协作式多任务调度实现并发。由用户代码显式控制(用户态调度而非操作系统内核调度),避免了线程上下文切换的开销,适合…

Muduo网络库实现 [十六] - HttpServer模块

目录 设计思路 类的设计 模块的实现 公有接口 私有接口 疑问点 设计思路 本模块就是设计一个HttpServer模块,提供便携的搭建http协议的服务器的方法。那么这个模块需要如何设计呢? 这还需要从Http请求说起。 首先从http请求的请求行开始分析&…

关于进程状态

目录 进程的各种状态 运行状态 阻塞状态 挂起状态 linux中的进程状态、 进程状态查看 S状态(浅睡眠) t 状态(追踪状态) T状态(暂停状态) ​编辑 kill命令手册 D状态(深度睡眠&#…

SQL注入 01

0x01 用户、脚本、数据库之间的关系 首先客户端发出了ID36的请求,脚本引擎收到后将ID36的请求先代入脚本的sql查询语句Select * from A where id 36 , 然后将此代入到数据库中进行查询,查到后将返回查询到的所有记录给脚本引擎,接…