【SpringCloud】为什么选择微服务?

一般的平台会遇到的问题:

服务配置复杂。基础服务多,服务的资源配置复杂,传统方式管理服务复杂

服务之间调用复杂。检索服务、用户中心服务等,服务之间的调用复杂,依赖多

服务监控难度大。服务比较多,机器部署复杂,服务存活监控、业务是否正常监控尤为重要

服务化测试问题。服务依赖性比较大,测试一个小的功能,周边服务也需要启动

那么微服务的架构有什么优势呢?

先来看看两者的区别

|-----------|------------|--------------|
| | 传统单体架构 | 分布式微服务架构 |
| 新功能开发 | 需要时间 | 容器开发和实现 |
| 部署 | 不经常且容易部署 | 经常发布,部署复杂 |
| 隔离性 | 故障影响范围大 | 故障影响范围小 |
| 架构设计 | 难度小 | 难度级数增加 |
| 系统性能 | 响应时间快,吞吐量小 | 响应时间慢,吞吐量大 |
| 系统运维 | 运维简单 | 运维复杂 |
| 技术 | 技术单一且封闭 | 技术多样且开放 |
| 测试和查错 | 简单 | 复杂 |
| 系统扩展性 | 扩展性很差 | 扩展性很好 |
| 系统管理 | 重点在于开发成本 | 重点在于服务治理和调度 |

由此可见,分布式系统虽然有一些优势,但也存在一些问题

  • 架构设计变得复杂(尤其是分布式事务)
  • 部署单个服务会比较快,但一次部署多个服务会变得复杂
  • 系统的吞吐量会变大,但是响应时间会变长
  • 运维复杂度会因为服务变多而变得很复杂
  • 架构复杂导致学习曲线变大
  • 测试和查错的复杂度增大
  • 技术很多样,带来维护和运维的复杂度提升
  • 管理分布式系统中的服务和调度变得困难且复杂

简而言之,分布式系统架构的难点在于系统设计、管理和运维

参考资料:《微服务架构实战》------ 张锋

一 叶 知 秋,奥 妙 玄 心

相关推荐
残花月伴5 分钟前
springCloud/Alibaba常用中间件之Seata分布式事务
分布式·spring cloud·中间件
zy happy7 小时前
搭建运行若依微服务版本ruoyi-cloud最新教程
java·spring boot·spring cloud·微服务·ruoyi
IT成长史12 小时前
deepseek梳理java高级开发工程师微服务面试题-进阶版
java·spring cloud·微服务
紫璨月12 小时前
Feign异步模式丢失上下文问题
spring cloud·openfeign
一零贰肆13 小时前
互联网大厂Java面试题:深入解析SpringCloud微服务架构中的服务注册与发现机制
java·微服务·nacos·面试题·springcloud
匆匆z215 小时前
AWS EC2 微服务 金丝雀发布(Canary Release)方案
微服务·云原生·金丝雀部署
Volunteer Technology21 小时前
SpringCloud Gateway知识点整理和全局过滤器实现
spring·spring cloud·gateway
残花月伴1 天前
springCloud/Alibaba常用中间件之Setinel实现熔断降级
spring·spring cloud·中间件
码农飞哥1 天前
互联网大厂Java求职面试实战:Spring Boot到微服务全景解析
java·spring boot·微服务·maven·hibernate·技术栈·面试技巧
胡斌附体1 天前
微服务调试问题总结
java·微服务·架构·调试·本地·夸微服务联调