feign使用熔断器,直接熔断

项目中配置熔断器,开启之后直接熔断走fallback,明明下游服务可用!!!!
各种debug,看源码,差资料,无解。debug只是显示阻塞。

后来我再fallback方法中手工抛了个异常RuntimeException,终于在控制台得到异常信息,指向到某个过滤器。

@Override
    public String test() {
        System.out.println("进入熔断器了");
        throw new RuntimeException();      
    }

如果不手工抛这个RuntimeException。不会读取到任何异常。

异常所在如下:

public class FeignRequestInterceptor implements RequestInterceptor {

/**
     * 设置请求头,传递登录信息
     *
     * @param template

*/

    @Override
    public void apply(RequestTemplate template) {
        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
                .getRequestAttributes();
        HttpServletRequest request = attributes.getRequest();
        Enumeration<String> headerNames = request.getHeaderNames();
        if (headerNames != null) {
            while (headerNames.hasMoreElements()) {
                String name = headerNames.nextElement();
                String values = request.getHeader(name);
                template.header(name, values);
            }
        }
    }
}

这个过滤中,我们对feign的header进行了传递,但是报了request的空指针异常在fallback中手工抛异常后,控制台报错如下:

Caused by: java.lang.NullPointerException
	at com.chinamobile.bcsec.usercontroller.interceptor.FeignRequestInterceptor.apply(FeignRequestInterceptor.java:27)
	at feign.SynchronousMethodHandler.targetRequest(SynchronousMethodHandler.java:163)
	at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:89)
	at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:77)
	at feign.hystrix.HystrixInvocationHandler$1.run(HystrixInvocationHandler.java:107)
	at com.netflix.hystrix.HystrixCommand$2.call(HystrixCommand.java:302)
	at com.netflix.hystrix.HystrixCommand$2.call(HystrixCommand.java:298)
	at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:46)
	... 26 more

至此终于确定是此异常导致的熔断。
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
这个强转需要判断一下,再转,否者下面一行会存在空指针的风险。熔断器就会直接熔断,不做任何提示。
HttpServletRequest request = attributes.getRequest();
很坑,如果不是凑巧在fallback中手动抛了个运行时异常,系统根本不会报异常信息,不知道为何。

  • 6
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
使用Feign进行远程服务调用时,如果并发量达到了10个以上的请求,由于某些原因,服务器无法处理这么多的请求,就会导致Feign出现熔断Feign是一种基于注解的声明式Web服务客户端,它简化了远程服务调用的过程。其内部使用Hystrix作为默认的容错和熔断器实现。Hystrix是一个弹性、容错和容灾的库,当底层服务不可用或超过阈值时,它会自动断开请求的链路,从而保护系统的稳定性。 当Feign的并发量达到10个后,说明系统的负载已经相当高。如果此时继续发送请求,服务器可能无法处理这么多的请求,导致服务出现延迟甚至崩溃。为了保护系统的稳定性,Hystrix会自动触发熔断机制。 熔断机制的主要目的是快速失败,而不是一直等待服务恢复正常。一旦Feign发现熔断条件已满足,它会停止发送请求给服务器,并返回事先定义好的降级结果。这个降级结果通常是由开发者预先配置的,比如返回一个错误提示或者一个默认值。 熔断机制会在一段时间后尝试发送新的请求,检测服务器是否已经恢复正常。如果服务器恢复正常,熔断器会逐渐关闭,Feign可以继续发送请求。但如果服务器仍然不能处理高并发的请求,熔断器会保持打开状态,直到服务器的负载下降到可接受的范围。 总结来说,当使用Feign进行远程服务调用时,如果并发量达到10个后熔断了,这意味着系统的负载已经超出了可承受的范围,Hystrix触发了熔断机制来保护系统的稳定性,避免进一步的请求导致服务崩溃。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值