美文网首页程序员@IT·互联网java高级开发群
线上防雪崩利器——熔断器设计原理与实现

线上防雪崩利器——熔断器设计原理与实现

作者: Java技术剑 | 来源:发表于2018-09-25 17:01 被阅读262次

前言

这是一篇根据工作中遇到的问题总结出的最佳实践。

上周六,我负责的业务在凌晨00-04点的支付全部失败了。

结果一查,MD,晚上银行维护,下游支付系统没有挂维护公告,在此期间一直请求维护中的银行,当然所有返回就是失败了,有种欲哭无泪的感觉,锅让业务来背。

为了杜绝在此出现这种大面积批量的支付失败情况发生,保障系统的健壮性。我需要个在集中性异常的时候可以终止请求,当服务恢复,恢复请求。

我想了一些方式,最后,觉得熔断器比较适合干这种事情。

状态模式

我们已一个开关为例

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

熔断器基本原理

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

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

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

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

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

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

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

简单的本地熔断器实现

一个基本的本地熔断器。

image.png

对外暴露接口

熔断器对外暴露接口

熔断器状态对外暴露接口

三种状态

关闭状态实现:

打开状态

半开状态

熔断器

抽象熔断器

本地熔断器

测试例子

结果

欢迎工作一到五年的Java工程师朋友们加入Java架构开发:744677563

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!

相关文章

  • 线上防雪崩利器——熔断器设计原理与实现

    前言 这是一篇根据工作中遇到的问题总结出的最佳实践。 上周六,我负责的业务在凌晨00-04点的支付全部失败了。 结...

  • 防雪崩利器:熔断器 Hystrix 的原理与使用

    前言 分布式系统中经常会出现某个基础服务不可用造成整个系统不可用的情况, 这种现象被称为服务雪崩效应. 为了应对服...

  • SpringCloudHystrix.md

    SpringCloudHystrix 简介 服务容错机制防雪崩利器基于Netflix对应的Hystrix 功能 1...

  • 分布式服务-防雪崩利器Hystrix(熔断器)

    前言 分布式系统中经常会出现某个基础服务不可用造成整个系统不可用的情况, 这种现象被称为服务雪崩效应. 为了应对服...

  • RTOS基础(邮箱)

    邮箱的原理与创建 问题概述 设计原理 设计实现 邮箱的获取和释放 设计原理 设计实现 邮箱的清空与删除 设计原理 ...

  • SpringCloud-4之熔断器和雪崩效应

    使用 Ribbon 和 Spring Cloud 实现客户端负载均衡-使用熔断器防止服务雪崩官网demo:http...

  • RTOS(事件标志组)

    事件标志组的原理与创建 问题概述 设计原理 设计实现 事件标志组的等待与通知 设计需求 设计原理 设计实现 事件标...

  • RTOS基础(计数信号量)

    计数信号量的原理与创建 概述 设计原理 设计实现 计数信号量的获取与释放 设计原理 设计实现 计数信号的删除与状态...

  • RTOS基础(存储块)

    存储块的原理与创建 问题概述 设计原理 设计实现 存储块的获取与释放 设计原理 设计实现 存储块的删除和状态查询 ...

  • RTOS基础(事件控制块实现)

    时间控制块的原理与创建 问题概述 解决方案 事件控制块原理 设计实现 事件的等待与通知 概述 设计原理 设计实现 ...

网友评论

  • 傲雪星枫:与令牌桶限流机制区别是什么?
  • MrBeanPlating:看你标题,从我的行业来看,还以为是保险丝类别呢!见笑了。。。传统的保险丝结构,为具有一线圈或保险丝材料,并将保险丝材料密封于硬玻璃、陶瓷材料或其他绝缘体材料所制成的管体管体的两端分别为端电极,利用端电极与电路板上的焊接点连接,使电流通过保险丝,当瞬间的电流超过预定的电流额值时,保险丝材料将因瞬间过大的电流所产生的热量而被高温熔断,进而形成断路,使过大的电流不再进入电路中,以保护电路及电器设备免于损坏。
  • ImClive:如果0至4点,所依赖银行底层支付一直是挂掉的,那这个熔断起到什么作用呢,给用户返回信息说稍后重试?实际还是得到几个小时后才能支付成功吧。
    城市独行客3:@ImClive 起码能防止阻塞请求,不行的话立马给你断了
    骑小猪看流星:@ImClive 是的

本文标题:线上防雪崩利器——熔断器设计原理与实现

本文链接:https://www.haomeiwen.com/subject/weploftx.html