本文主要是介绍Circuit Breaker(电路熔断器)模式原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 简介
- 参考资料
简介
我们知道,在微服务架构中,一个服务通过远程调用去访问另一个服务是很常见的事,服务运行在不同的进程甚至不同的机器上,服务间的调用可能会一直得不到响应直到超时失败,更严重的是,如果有多个远程调用同时请求了一个没有响应的服务,可能会耗尽系统的资源从而导致跨服务的级联失败,为了防止这种灾难性的结果,有人(据说是一个叫Michael Nygard的人)就提出了一种叫做Circuit Breaker的模式,中文一般翻译为电路熔断器模式,它的原理就像电路中的保险丝一样,当电路出现异常(比如短路)时就会自动熔断,虽然熔断后电用不了了,但也防止了更严重的后果发生。所以当我们看到Circuit Breaker这个术语时,如果感到疑惑不妨把它想象成一根保险丝(或者阀门),或许会容易理解很多。
Circuit Breaker的思路其实非常简单,我们把服务被调用的方法放到Circuit Breaker中保护起来,Circuit Breaker会监控这些方法的失败,一旦失败次数达到一个阈值,Circuit Breaker就会被触发,后续对这些被保护的方法的调用都会直接失败,由于这些方法根本就没有执行过,所以也不会出现超时的情况,如下图:
一般情况下我们还会在Circuit Breaker被触发的时候发送一些告警信息,来提醒我们系统中出现了问题,从而可以快速地发现系统中的异常并进行处理。
在SpringCloud中,Netflix组件下有一个叫Hystrix的库,实现了Circuit Breaker模式。
参考资料
电路熔断器模式
这篇关于Circuit Breaker(电路熔断器)模式原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!