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

微服务架构陷阱与挑战

微服务架构6大陷阱

现在微服务的基础设施还是越来越完善了,现在基础设施缺乏的问题逐渐被解决了。

拆分粒度太细,服务关系复杂

拆分降低了服务的内部复杂度,但是提升了系统的外部复杂度,服务越多,服务和服务之间的连接关系越混乱。

拆分粒度太细,团队效率下降

拆分粒度太细,问题定位困难

不是很好排查问题,链路太长了。

拆分粒度太细,系统性能下降

基本上接口间的调用(包含接口的业务逻辑执行完毕),大概的耗时是50ms,以后估计链路的耗时,就按照这个估计就好了。

缺乏基础设施,无法快速交付

缺乏基础设施,服务管理混乱

微服务架构4大挑战

微服务架构示意

左边是微服务架构,右边是单体架构

主要区别有两个:服务的拆分和数据的拆分

微服务技术挑战

只拆分代码,不拆分数据库,算不算微服务?

不算。

BASE 理论之最终一致性

一致性是有时间的,看你业务的忍受程度

业务级分布式事务-本地事务消息

业务级分布式事务-消息队列事务消息

业务级分布式事务-TCC

全局幂等

全局幂等设计示例-正常处理1

B收到之后,先根据全局ID判断状态是不是done,如果是done就直接返回,如果不是就处理业务。

第4步如果处理业务成功后,更新消息状态失败,如何应对这种情况?

要用事务来保证,比如要同时成功。

全局幂等设计示例-正常处理2

B服务不需要先记录消息了,直接同时完成业务和消息的done写入,针对这个方案,如果2消息丢了,那么A服务重发就好了

接口兼容 和 接口循环调用

2这种方式是加if else,这样的风险会很高

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

相关文章:

  • react的事件绑定
  • ASP.NET Core 入门教学二十九 DDD设计
  • Rocprofiler测试
  • 基于python flask的高血压疾病预测分析与可视化系统的设计与实现,使用随机森林、决策树、逻辑回归、xgboost等机器学习库预测
  • Lombok 与 EasyExcel 兼容性问题解析及建议
  • Kubeadm快速安装 Kubernetes集群
  • OpenJudge | 八皇后问题
  • C#往压缩包Zip文件的文件追加数据
  • 局域网共享文件夹:您没有权限访问,请与网络管理员联系
  • 科技修复记忆:轻松几步,旧照变清晰
  • java -versionbash:/usr/lib/jvm/jdk1.8.0_162/bin/java:无法执行二进制文件:可执行文件格式错误
  • 大数据-141 - ClickHouse 集群 副本和分片 Zk 的配置 Replicated MergeTree原理详解
  • Django-cookie和session
  • 前端进阶,使用Node.js做中间层,实现接口转发和服务器渲染
  • iPhone 16系列:熟悉的味道,全新的体验
  • 改进拖放PDF转换为图片在转换为TXT文件的程序
  • 在 Flutter 开发中如何选择状态管理:Provider 和 GetX 比较
  • python中ocr图片文字识别样例(二)
  • 2024 新手指南:轻松掌握 Win10 的录屏操作
  • 无人机黑飞打击技术详解
  • GoFly快速开发框架/Go语言封装的图像相似性比较插件使用说明
  • 【牛客】小白赛101-B--tb的字符串问题
  • 企业专用智能云盘 | 帮助企业便捷管控企业文档 | 天锐绿盘云文档安全管理系统
  • 软件工程专业未来发展方向
  • 【204】C++的vector删除重复元素
  • 模型案例:| 行李检测模型!
  • 【PostgreSQL】PostgreSQL SQL语句整理:掌握核心技能
  • 电风扇制造5G智能工厂物联数字孪生平台,推进制造业数字化转型
  • Zookeeper安装使用教程
  • Linux C# DAY3