spring cloud gateway集成hystrix全局断路器操作

网友投稿 521 2022-10-11


spring cloud gateway集成hystrix全局断路器操作

gateway集成hystrix全局断路器

pom.xml添加依赖

org.springframework.cloud

spring-cloud-starter-netflix-hystrix

在配置文件中,增加spring.cloud.gateway.default-filters:

default-filters:

- name: Hystrix

args:

name: fallbackcmd

fallbackUri: forward:/fallbackcontroller

一定要注意是spring.cloud.gateway.default-filters这个配置节。

如上的配置,将会使用HystrixCommand打包剩余的过滤器,并命名为fallbackcmd,我们还配置了可选的参数fallbackUri,降级逻辑被调用,请求将会被转发到URI为/fallbackcontroller的控制器处理。

定义降级处理如下:

@RequestMapping(value = "/fallbackcontroller")

public Map fallBackController() {

Map res = new HashMap();

res.put("code", http://"-100");

res.put("data", "service not available");

return res;

}

此时可以设置hystrix超时时间(毫秒) ,默认只有2秒

hystrix:

command:

default:

execution:

isolation:

thread:

timeoutInMilliseconds: 30000

示例代码:

https://github.com/wanghongqi/springcloudconsul_test/tree/master/springtest_gateway

spring cloud gateway 全局熔断

熔断主要保护的是调用方服务,如某A服务调用B服务的rpc接口,突然B服务接口不稳定,表现为接口延迟或者失败率变大。

这个时候如果对B服务调用不能快速失败,那么会导致A服务大量线程资源无法释放导致最终A服务不稳定,故障点由B服务传递到A服务,故障扩大。

熔断就是在B服务出现故障的情况下,断开对B的调用,通过快速失败来保证A服务的稳定。

一:Gateway项目maven引入依赖包

Spring Cloud Gateway 利用 Hystrix 的熔断特性,在流量过大时进行服务降级,同样我们还是首先给项目添加上依赖

org.springframework.boot

spring-boot-starter-actuator

二:创建熔断后转发的请求

@RestController

public class FallbackController {

private Logger log= LoggerFactory.getLogger(getClass());

@RequestMapping("/error/fallback")

public Object fallacak(){

log.info("熔断处理!!!");

return "Service Error!!!";

}

}

三:yml配置

#全局熔断拦截器

default-filters:

- name: Hystrix

args:

name: fallbackcmd

fallbackUri: forward:/error/fallback

- name: Retry

args:

retries: 3

statuses: BAD_GATEWAY,BAD_REQUEST

methods: GET,POST

Hystrix是Gateway以封装好的过滤器。如果不了解请查看:GatwayFilter工厂

name:即HystrixCommand的名字

fallbackUri:forward:/error/fallback 配置了 fallback 时要会调的路径,当调用 Hystrix 的 fallback 被调用时,请求将转发到/error/fallback 这个 URI

Retry 通过这四个参数来控制重试机制: retries, statuses, methods, 和 series

retries:重试次数,默认值是 3 次

statuses:HTTP 的状态返回码,取值请参考:org.springframework.http.HttpStatus

methods:指定哪些方法的请求需要进行重试逻辑,默认值是 GET 方法,取值参考:org.springframework.http.HttpMethod

series:一些列的状态码配置,取值参http://考:org.springframework.http.HtMVddtaitpStatus.Series。符合的某段状态码才会进行重试逻辑,默认值是 SERVER_ERROR,值是 5,也就是 5XX(5 开头的状态码),共有5 个值。

# hystrix 信号量隔离,3秒后自动超时

hystrix:

command:

fallbackcmd:

execution:

isolation:

strategy: SEMAPHORE

thread:

timeoutInMilliseconds: 3000

fallbackcmd 此处需要和上面设置的HystrixCommand一致

timeoutInMilliseconds 设置超时时间


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:史上最大CPU缺陷Meltdown融毁和Spectre幽灵来袭,各网络设备厂家反馈以及解决方案汇总
下一篇:Pandas库DataFrame的排序(Dataframe排序)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~