前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。
一、为什么要有熔断
在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的 “雪崩” 效应。
为了解决这个问题,业界提出了断路器模型 。
以上出自:https://blog.csdn.net/forezp/article/details/81040990
二、熔断实现
1. 首先 启动 注册中心 eureka 工程、服务生产者 see-param 工程(8803端口)、
服务消费者 feign 工程(8702端口)、服务消费者 ribbon 工程(8701 端口)。
(生产者和消费者这 2 个概念是相对的。在不同的业务场景中,2 者身份可互换。或多服务时,同一服务可兼具 2 个身份。)
分别访问 生产者:
2. feign 中熔断器实现。
配置文件中开启熔断:
# 开启断熔器: ( Feign 自带断路器,但默认为不开启: false)
feign.hystrix.enabled=true
在 SeeParamService 类中 @FeignClient 注解中加上参数 fallback ,并指明熔断方法实现类。
书写 熔断方法实现类:
package com.feign.servicefeign;import org.springframework.stereotype.Component;/*** @author yujiang* @description 迷断回调方法类* @date 2019/7/24 9:39*/// 注入IOC容器中,把本类交给 spring 管理
@Component
public class SeeParamError implements SeeParamService {@Overridepublic String seeParam(String param) {return " 乖乖加班吧,服务挂了,搬砖,搬砖 ... ";}}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,feign 熔断生效 。
3. ribbon 中熔断器实现。
ribbon 并不自带迷断功能,故要引入依赖:
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId></dependency>
工程启动类加注解 @EnableHystrix ,开启熔断。
SeeParamService 类中,在要实现熔断的方法上加注解:@HystrixCommand(fallbackMethod = "熔断实现方法名"),如:
package com.ribbon.serviceribbon;import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;/*** @author yujiang* @description* @date 2019/7/22 11:45*/
@Service
public class SeeParamService {@AutowiredRestTemplate restTemplate;/*** 注解 @HystrixCommand :* 开启熔断器,指定熔断时回调方法为 seeParamError** @param param* @return*/@HystrixCommand(fallbackMethod = "seeParamError")public String seeService(String param) {return restTemplate.getForObject("http://see-param/seeParam?param=" + param, String.class);}/*** 熔断 调用此方法** @return*/public String seeParamError(String param) {return " 哎,别瞅了,别瞅了,服务已经 go die ...";}}
此时, 关闭服务生产者 see-param 工程,并再访问其服务:
至此,ribbon 熔断生效 。
--------------------------------------------------------------
下一篇:springCloud - 第6篇 - 网关的实现:ZUUL
源码见:https://gitee.com/FJ_WoMenDeShiJie/springcloud-feign
https://gitee.com/FJ_WoMenDeShiJie/springcloud-ribbon
--------------------------------------------------------------
PS:这个系列不定时更新,只是个人的学习分享,
内容全程参考书目:
《Spring Cloud 与 Docker 微服务架构空实战 》、
《Spring Cloud 微服务实战》及此书作者博客:http://blog.didispace.com/spring-cloud-learning/
《深入理解 Spring Cloud 与微服务构建》及此书作者博客:https://blog.csdn.net/forezp/article/details/70148833
--------------------------------------------------------------