万事皆有因
玩过 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