如何全局捕捉 eureka 通过 Feign 远程调用出现的异常

万事皆有因

玩过 springcloud 的微服务架构的小伙伴们都知道,在我们通过 eureka 远程调用其他的微服务的时候,防止网络抖动或者程序异常等情况,往往会加上 hystrix 断路器对异常进行处理,但是往往在处理的时候一般都是记录一些日志告诉开发者哪里出问题了,参数是什么,又或者其他的处理

然而,很多人使用 Feign 的时候 rollback 都是继承被调用的 FeignClient 的一个子类,然后里面重写接口的方法,记录日志等等操作。

想想一下,其实处理这些 rpc 异常的方式基本差不多,然后每一个方法都需要重新写一遍,强迫症严重的人肯定不允许这样的事情发生,那么我们该如何做到通过一个方法将这些错误日志将调不同接口方法异常打印出来呢?

突然灵光一闪

该怎么做呢?当时我想啊,若能动态生成其子类的方法是不是可以达到目的呢?于是通过动态代理去实现,下面给出代码。

  • rollback 工厂类

import com.qts.agent.web.util.ReflectionUtil;
import feign.hystrix.FallbackFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import java.lang.reflect.Proxy;

/**
 * 基础的远程异常捕捉
 *
 * @author 阿导
 * @CopyRight 万物皆导
 * @created 2018年08月09日 14:56:00
 * @Modified_By 阿导 2018/8/9 14:56
 */
@Component
public class BaseFailedFactory<T> implements 
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值