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

微服务保护和分布式事务-01.雪崩问题-原因分析

一.雪崩问题

我们将单体架构拆分成微服务架构,在拆分的过程中我们就遇到了各种各样的问题。比如我们在拆分后各个微服务之间要进行相互调用,这种跨服务之间的远程调用,我们使用OpenFeign来解决。

这样的调用错综复杂,我们要维护微服务之间的地址和状态,这就要用到nacos服务治理组件。

服务多了之后不仅仅服务之间调用复杂,前端也不清楚哪个请求要调用哪个微服务。因此我们引入了网关,网关一方面可以实现前端请求路由转发到对应的微服务。另一方面也可以对前端请求进行身份的认证。

后来我们又发现微服务越来越多,每个微服务都有自己的配置文件,这些配置太多太复杂,如果配置出现变更我们还需要重启服务,这样一来服务的可用性就降低了,为了解决这一问题我们又学习了配置管理。还是nacos的功能。一方面可以显示配置的抽取和共享,简化微服务的配置。另一方面还可以实现微服务的配置热更新,修改配置无需重启,这样可以提高整个服务的可用性。

以上就是我们目前学习的所有微服务组件。

但是我们还要掌握一下能力:

1.服务保护:如果有的服务出现了故障,应该对于这个情况有对应的方案和健壮性的处理。

2.分布式事务:以前单体项目不管项目多复杂,都能够满足事务的ACID特性,但是拆分成微服务后由于每个服务是独立的,他们各自去操作数据库。这样就破坏了事物的ACID特性。这又该怎么处理。

我们首先来看服务保护经常会碰到的问题:雪崩问题。

二.雪崩问题

如果商品服务由于故障崩溃了,会导致很多由购物车服务发向商品服务的请求得不到响应。这就会导致越来越多的请求堆积到购物车服务这里。从而导致很多用户对购物车服务的请求得不到处理。最后很多服务堆积来不及处理会导致Tomcat资源耗尽。

一旦资源耗尽,就算有新的请求进入到购物车服务,就算他不是请求商品服务的,而是请求其他服务的,但是由于资源耗尽也无法请求。就会导致整个服务瘫痪。

http://www.xdnf.cn/news/1381555.html

相关文章:

  • 步进电机、直流电机常见问题
  • APP手游使用游戏盾SDK为何能有效抵御各类攻击?
  • Java全栈工程师的实战面试:从基础到微服务的全面解析
  • 算法 --- 二分
  • Paimon——官网阅读:非主键表
  • CLIP图像特征提取:`CLIPVisionModel` vs `CLIPModel.get_image_features()`,哪种更适合你的任务?
  • [sys-BlueChi] docs | BluechiCtl命令行工具
  • 滑台模组如何实现电子制造精密加工?
  • Java 大视界 -- 基于 Java 的大数据实时流处理在智能电网分布式电源接入与电力系统稳定性维护中的应用(404)
  • 零基础开发应用:cpolar+Appsmith平民化方案
  • HVV面经总结(二)
  • MySQL事务ACID特性
  • 内网穿透工具【frp】的核心功能底层处理逻辑解析
  • Linux部分底层机制
  • LeetCode-279. 完全平方数
  • Linux 软件编程(十三)网络编程:TCP 并发服务器模型与 IO 多路复用机制、原理epoll
  • 工业机器人如何通过Modbus TCP转CanOpen网关高效通信!
  • HTML贪吃蛇游戏实现
  • RAW API 的 TCP 总结2
  • 鸿蒙Harmony-从零开始构建类似于安卓GreenDao的ORM数据库(四)
  • 刷题日记0828
  • 未来模型会转向多模态吗
  • Logstash数据迁移之mysql-to-kafka.conf详细配置
  • 领悟8种常见的设计模式
  • 导入文件允许合并表格
  • HBase Compaction HFile 可见性和并发安全性分析
  • audioMAE模型代码分析
  • 流程控制语句(3)
  • 帕萨特盘式制动器cad+设计说明书
  • 【C语言16天强化训练】从基础入门到进阶:Day 13