美文网首页
5. 微服务保护 - Sentinel - Fallback (

5. 微服务保护 - Sentinel - Fallback (

作者: 右耳菌 | 来源:发表于2025-09-19 19:28 被阅读0次

建议方式二


案例

这里我们演示方式二的失败降级处理。

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

但是未被限流的请求延时依然很高:

导致最终的平局响应时间较长。


如果觉得有收获,欢迎点赞和评论,更多知识,请点击关注查看我的主页信息哦~

相关文章

网友评论

      本文标题:5. 微服务保护 - Sentinel - Fallback (

      本文链接:https://www.haomeiwen.com/subject/bcmcbjtx.html