建议方式二
案例
这里我们演示方式二的失败降级处理。
1. 自定义类,实现FallbackFactory,编写对某个FeignClient的fallback逻辑
package com.hmall.api.client.fallback;
import com.hmall.api.client.ItemClient;
import com.hmall.api.dto.ItemDTO;
import com.hmall.api.dto.OrderDetailDTO;
import com.hmall.common.exception.BizIllegalException;
import com.hmall.common.utils.CollUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.cloud.openfeign.FallbackFactory;
import java.util.Collection;
import java.util.List;
@Slf4j
public class ItemClientFallback implements FallbackFactory<ItemClient> {
@Override
public ItemClient create(Throwable cause) {
return new ItemClient() {
@Override
public List<ItemDTO> queryItemByIds(Collection<Long> ids) {
log.error("远程调用ItemClient#queryItemByIds方法出现异常,参数:{}", ids, cause);
// 查询购物车允许失败,查询失败,返回空集合
return CollUtils.emptyList();
}
@Override
public void deductStock(List<OrderDetailDTO> items) {
// 库存扣减业务需要触发事务回滚,查询失败,抛出异常
throw new BizIllegalException(cause);
}
};
}
}
2. 在hm-api模块中的com.hmall.api.config.DefaultFeignConfig类中将ItemClientFallback注册为一个Bean
3. 在hm-api模块中的ItemClient接口中使用ItemClientFallbackFactory:
4. 重启后,再次测试,发现被限流的请求不再报错,走了降级逻辑:
image.png
但是未被限流的请求延时依然很高:
导致最终的平局响应时间较长。
如果觉得有收获,欢迎点赞和评论,更多知识,请点击关注查看我的主页信息哦~