温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java熔断器设计如何实现

发布时间:2022-01-14 20:06:29 来源:亿速云 阅读:237 作者:iii 栏目:编程语言

这篇文章主要介绍“java熔断器设计如何实现”,在日常操作中,相信很多人在java熔断器设计如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java熔断器设计如何实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

状态模式

我们已一个开关为例

java熔断器设计如何实现

java熔断器设计如何实现

在每一种状态下,context不必关心每一种状态下的行为。交给每一种状态自己处理。

熔断器基本原理

熔断器是当依赖的服务已经出现故障时,为了保证自身服务的正常运行不再访问依赖的服务,防止雪崩效应

java熔断器设计如何实现

熔断器本身就是一个状态机。

关闭状态:熔断器的初始化状态,该状态下允许请求通过。当失败超过阀值,转入打开状态,

打开状态:熔断状态,该状态下不允许请求通过,当进入该状态经过一段时间,进入半开状态。

半开状态:在半开状态期间,允许部分请求通过,在半开期间,观察失败状态是否超过阀值。如果没有超过进入关闭状态,如果超过了进入关闭状态。如此往复。

之前,查了一些资料,网上所有的资料几乎都是针对Hystrix的。这个只是针对分布式系统的接口请求,并不能运用于我们的系统中,因此这种情况下,根据原理自己实现了一个基本的分布式熔断器,数值与计数器存放在redis中,因为redis的操作客户端不一样,我就以本地熔断器为例,讲解熔断器实现。

希望我的文章能对于理解熔断器,以及需要熔断器的人有所帮助。

简单的本地熔断器实现

一个基本的本地熔断器。

java熔断器设计如何实现

image.png

对外暴露接口

熔断器对外暴露接口

java熔断器设计如何实现

熔断器状态对外暴露接口

java熔断器设计如何实现

三种状态

关闭状态实现:

java熔断器设计如何实现

java熔断器设计如何实现

打开状态

java熔断器设计如何实现

半开状态

java熔断器设计如何实现

java熔断器设计如何实现

熔断器

抽象熔断器

java熔断器设计如何实现

java熔断器设计如何实现

本地熔断器

java熔断器设计如何实现

测试例子

java熔断器设计如何实现

java熔断器设计如何实现

结果

java熔断器设计如何实现

到此,关于“java熔断器设计如何实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI