Feign整合Sentinel实现服务降级

为什么要做降级服务

在微服务架构中,服务之间的调用是非常频繁的。但是,在分布式环境下,服务调用可能会因为网络问题、服务过载或服务不可用等原因而失败。这时,如果没有适当的容错机制,可能会导致级联失败,影响整个系统的可用性。

降级是一种重要的容错机制,它可以:

  1. 保护系统: 当被调用的服务出现问题时,通过降级可以避免调用方服务被拖垮。

  2. 提高用户体验: 即使部分功能不可用,系统仍然可以返回一个默认或缓存的结果,而不是直接报错。

  3. 减少资源消耗: 在高并发场景下,可以通过降级减少对某些非核心服务的调用,从而节省系统资源。

  4. 快速失败: 当知道某个调用注定会失败时,可以快速返回,而不是等待超时,这样可以提高系统的响应速度。

整合步骤

  1. Feign接口:
java 复制代码
@FeignClient(value = "remark-service",fallbackFactory = RemarkClientFallback.class)

这里定义了一个Feign客户端,用于调用名为"remark-service"的服务。fallbackFactory指定了降级处理的工厂类。

  1. 降级类:
java 复制代码
@Override
public RemarkClient create(Throwable cause) {
    log.error("调用remark服务员降级了{}", cause);
    return new RemarkClient() {
        @Override
        public Set<Long> getLikeStatusByIds(List<Long> bizIds) {
            return null;
        }
    };
}

这个方法会在发生异常时被调用。它记录了错误日志,并返回一个新的RemarkClient实现,这个实现的方法会返回默认值(这里是null)。

  1. 配置类:
java 复制代码
@Configuration
public class FallbackConfig {
    @Bean
    public RemarkClientFallback remarkClientFallback(){
        return new RemarkClientFallback();
    }
}

这个配置类将RemarkClientFallback注册为Spring Bean,使其可以被自动注入到需要的地方。

  1. Spring.Factories:
properties 复制代码
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
  com.tianji.api.config.FallbackConfig

这个配置确保FallbackConfig类被Spring Boot自动配置机制加载,从而激活降级功能。

  1. 配置文件:
properties 复制代码
feign:
  sentinel:
    enabled: true

这个配置启用了Feign对Sentinel的支持,允许使用Sentinel来控制服务调用的流量和实现降级。

相关推荐
会飞的大可4 天前
Redis Sentinel 高可用方案在WMS仓储管理系统的应用
redis·sentinel
zs宝来了6 天前
Redis 哨兵机制:Sentinel 原理与高可用实现
redis·sentinel·高可用·源码解析·哨兵
leo_messi946 天前
2026版商城项目(二)-- 压力测试&缓存
java·缓存·压力测试·springcloud
梵得儿SHI6 天前
SpringCloud 秒杀系统生产级落地:Sentinel+Redis 联合优化,从限流防刷到库存闭环,彻底解决超卖 / 宕机 / 恶意刷
redis·spring cloud·sentinel·分布式限流·百万级·瞬时高并发·产级秒杀系统解决方案
總鑽風8 天前
springcloud2023_alibaba_sso单点登录_授权码模式(已跑通)
springcloud·单点登录·sso·授权码模式
8Qi88 天前
Redis哨兵模式(Sentinel)深度解析
java·数据库·redis·分布式·缓存·sentinel
无名-CODING8 天前
Java 爬虫零基础入门:从 HTTP 到 Jsoup 实战
spring cloud·gateway·sentinel
会飞的大可9 天前
Spring Cloud Alibaba全景:Nacos、Sentinel、Seata整合实战
sentinel·wpf
總鑽風9 天前
springcloudalibaba2021-SSO 单点登录_密码模式
springcloud·alibaba·sso
无名-CODING9 天前
SpringCloud 网关与熔断:Gateway + Sentinel 快速入门
spring cloud·gateway·sentinel