Sentinel隔离、降级、授权规则详解


上一期教程讲解了 Sentinel 的限流规则: Sentinel限流规则,这一期主要讲述 Sentinel 的 隔离、降级和授权规则

虽然限流可以尽量避免因高并发而引起的服务故障,但服务还会因为其它原因而故障。而要将这些故障控制在一定范围,避免雪崩,就要靠线程隔离(舱壁模式)和熔断降级手段了

不管是线程隔离还是熔断降级,都是对客户端(调用方) 的保护

Feign整合Sentinel

在 SpringCloud 中,微服务调用一般都是通过 Feign 来实现的,因此做客户端保护必须整合Feign和Sentinel

Feign 的使用在之前的教程中有详细讲解过:Eureka结合Feign

实现的步骤如下:

1.在调用方的 application.yml 文件中,开启 Feign 对 Sentinel 的支持

feign:
  sentinel:
    enabled: true # 开启feign对sentinel的支持

2.为 FeignClient 编写失败后的降级逻辑

这里有两种方式:

FallbackClass,这种方式无法对远程调用的异常做处理
FallbackFactory,这种方式可以对远程调用的异常做处理

这里我们选择 FallbackFactory

定义一个类 UserClientFallbackFactory(名字可以任意),然后实现接口 FallbackFactory<UserClient>,这里泛型要和对应的 Feign 客户端对应

@Component
public class UserClientFallbackFactory implements FallbackFactory<UserClient> {
   

    @Override
    public UserClient create(Throwable cause) {
   
        return new UserClient() {
   
            @Override
            public String user() {
   
                cause.printStackTrace();
                // 异常时返回空值
                return "";
            }
        };
    }
    
}

3.在 Feign 客户端的 @FeignClient 注解中,添加属性 fallbackFactory,值就是刚才定义的类的 class 对象

@FeignClient(name = "service2", url = "http://127.0.0.1:8082", fallbackFactory = UserClientFallbackFactory.class)

这里为了方便,就直接定义了对应服务的 url,如果结合了注册中心,这里只需要填写对应的服务名即可

4.启动测试

访问对应服务端点后,进入 Sentinel 控制台,可以看到如下界面,表示 Feign 已经成功整合了 Sentinel

image-20240724142527550

然后添加限流规则,将 QPS 设为 1,测试异常情况

image-20240724143327743

### Sentinel 的详细介绍 #### 工作原理 Sentinel 是阿里巴巴开源的一款面向分布式服务架构的流量防护组件,主要作用是在高并发场景下保护系统的稳定性[^1]。通过实时监控应用入口流量的各项指标(如QPS、响应时间),当检测到异常情况时自动触发熔断机制。 对于限流策略而言,Sentinel 提供了基于 QPS 和线程池两种模式来控制请求速率;而针对降级处理,则可以通过设定超时时间和异常比例阈值实现对不稳定接口调用的有效隔离[^2]。 ```java // 定义资源名称并设置规则 FlowRule rule = new FlowRule(); rule.setResource("example_api"); rule.setGrade(RuleConstant.FLOW_GRADE_QPS); rule.setCount(20); // 设置每秒最大允许访问次数为20次 ``` #### 配置方法 在 Java 应用程序中集成 Sentinel 主要分为以下几个方面: - **引入依赖**:项目需添加 `sentinel-core` 及其他所需模块作为 Maven 或 Gradle 依赖项; - **定义受保护资源**:利用注解方式标记需要被监控的服务端点或函数; - **配置规则**:可通过编码形式动态调整参数,亦支持借助可视化界面完成静态化配置文件编辑操作[^3]。 ```xml <!-- 添加Maven依赖 --> <dependency> <groupId>com.alibaba.csp</groupId> <artifactId>sentinel-core</artifactId> <version>x.x.x</version> </dependency> ``` #### 使用场景 适用于微服务体系下的 API 流量管理以及防止雪崩效应的发生,在面对突发大流量冲击时能够及时做出反应以保障核心业务正常运转。具体来说,可以应用于但不限于以下几种情形: - 实现自适应负载均衡从而优化整体性能表现[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值