什么是断路器
断路器模式源于Martin Fowler的Circuit Breaker一文。“断路器”本身是一种开关装置,用于在电路上保护线路过载,
当线路中有电器发生短路时,“断路器”能够及时的切断故障电路,防止发生过载、发热、甚至起火等严重后果。
在分布式架构中,断路器模式的作用也是类似的,当某个服务单元发生故障(类似用电器发生短路)之后,
通过断路器的故障监控(类似熔断保险丝),向调用方返回一个错误响应,而不是长时间的等待。
这样就不会使得线程因调用故障服务被长时间占用不释放,避免了故障在分布式系统中的蔓延.
Netflix Hystrix
在Spring Cloud中使用了Hystrix 来实现断路器的功能。Hystrix是Netflix开源的微服务框架套件之一,
该框架目标在于通过控制那些访问远程系统、服务和第三方库的节点,从而对延迟和故障提供更强大的容错能力。
Hystrix具备拥有回退机制和断路器功能的线程和信号隔离,请求缓存和请求打包,以及监控和配置等功能。
下面我们来看看如何使用Hystrix。
准备工作
启动spring-could,spring-cloud-provide,eureka-ribbon项目
pom.xml中引入依赖hystrix依赖
在eureka-ribbon的主类RibbonApplication中使用@EnableCircuitBreaker注解开启断路器功能
新增也service类
改变之前Controller中的方法使其掉用Service中的addService即可,没开服务可以发现浏览器中返回了error错误了。
完成