spring-cloud-gateway降级的实现
前言
本文主要研究一下springcloudgateway如何集成hystrix。
当下游接口负载很大,或者接口不通等其他原因导致超时,如果接口不熔断的话将会影响到下游接口得不到喘息,网关也会因为超时连接一直挂起,很可能因为一个子系统的问题导致整个系统的雪崩。所以我们的网关需要设计熔断,当因为熔断器打开时,网关将返回一个降级的应答。
Maven配置
添加hystrix依赖
pom.xml
org.springframework.cloud spring-cloud-starter-netflix-hystrix
项目实战
在provider1服务中添加一个方法,延时2秒返回响应。
@GetMapping("/timeout") publicStringtimeout(){ try{ Thread.sleep(2000); }catch(InterruptedExceptione){ e.printStackTrace(); } System.out.println("休眠了2秒"); return"timeouttest"; }
修改网关配置文件
server: port:2000 spring: application: name:idc-gateway2 redis: host:localhost port:6379 timeout:6000ms#连接超时时长(毫秒) jedis: pool: max-active:1000#连接池最大连接数(使用负值表示没有限制) max-wait:-1ms#连接池最大阻塞等待时间(使用负值表示没有限制) max-idle:10#连接池中的最大空闲连接 min-idle:5#连接池中的最小空闲连接 cloud: consul: host:localhost port:8500 gateway: discovery: locator: enabled:true#gateway可以通过开启以下配置来打开根据服务的serviceId来匹配路由,默认是大写 routes: -id:provider1 uri:lb://idc-provider1 predicates: -Path=/p1/** filters: -StripPrefix=1 -name:Hystrix args: name:default fallbackUri:forward:/defaultfallback#只有该id下的服务会降级 -id:provider2 uri:lb://idc-provider2 predicates: -Path=/p2/** filters: -StripPrefix=1 #hystrix信号量隔离,1.5秒后自动超时 hystrix: command: default: execution: isolation: strategy:SEMAPHORE thread: timeoutInMilliseconds:1500
网关添加降级处理类
@RestController publicclassFallbackController{ @RequestMapping("/defaultfallback") publicMapdefaultfallback(){ System.out.println("降级操作..."); Map map=newHashMap<>(); map.put("code",200); map.put("msg","服务超时降级"); map.put("data",null); returnmap; } }
降级测试
超时服务降级
curlhttp://localhost:2000/p1/timeout
返回
{"msg":"服务超时降级","code":200,"data":null}
其他异常
spring-cloud-gateway调用下游服务返回的异常,网关不做任何处理,会直接返回。大家想一下为什么在网关不去处理下游异常呢?因为很多时候下游的异常是包含有效信息的(异常信息千千万),如果在网关处做了统一返回,就失去了返回异常的意义。
spring-cloud-starter-netflix-hystrix内置的Hystrix过滤器是
HystrixGatewayFilterFactory。感兴趣的小伙伴可以自行阅读相关源码。
到此这篇关于spring-cloud-gateway降级的实现的文章就介绍到这了,更多相关spring-cloud-gateway降级内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。