SpringCloud中Sentinel基础场景和异常处理

        Sentinel 是一个由 阿里巴巴 开源的分布式系统流量控制组件,专注于为微服务架构提供流量控制、熔断降级、系统负载保护等功能。它特别适用于高并发、高可用性的分布式系统,能够帮助开发者保护系统免于因流量过载、系统崩溃、依赖不可用等情况而导致的服务不可用。

一,Sentinel 的核心功能

  • 流量控制(Traffic Control)

    • 限流:在服务接口或者资源上进行流量限制,确保系统在高负载情况下不会崩溃。
    • QPS(每秒查询数):对每秒请求数进行限制,超过设定阈值则拒绝请求。
    • 并发线程数控制:控制在某个资源上同时处理请求的线程数,避免系统资源被过度消耗。
  • 熔断降级(Circuit Breaker)

    • 当依赖服务出现故障时,Sentinel 可以自动进行熔断处理,防止故障扩展,降低系统负担。
    • 根据定义的规则进行降级,比如当请求的失败率超过设定阈值时,自动进行服务降级处理。
    • 降级模式:可以配置为流量的百分比降级或者固定的线程数降级。
  • 系统负载保护(System Load Protection)

    • Sentinel 可以通过系统负载(如 CPU、内存、RT 等)来控制流量,确保在资源紧张时不会对系统产生更大的压力。
    • 可以根据系统的实时负载状况动态调整请求的流量,保证系统的稳定性。
  • 热点参数限流(Hot Spot Parameter Flow Control)

    • 限流不仅仅可以基于资源来进行,也可以基于请求中的参数来进行。例如,可以限制某些特定参数的请求数量。
  • 监控与报警

    • Sentinel 提供了实时监控能力,可以通过 Web 控制台或者日志进行流量、系统负载、异常等信息的监控。
    • 支持与外部监控系统(如 Prometheus、Grafana 等)集成,帮助开发者实时了解系统状态。
  • 集群模式

    • Sentinel 支持集群模式,适用于微服务架构中的多服务间的流量控制。
    • 支持将流量控制策略分布到整个集群中,保证整个系统的流量调度和熔断降级的一致性。

二,使用 Sentinel

添加依赖: 在 Spring Boot 项目中集成 Sentinel,首先需要在 pom.xml 中添加相关的依赖:
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-core</artifactId>
    <version>1.8.3</version>
</dependency>
使用 @SentinelResource 注解: 在方法上使用 @SentinelResource 注解来定义流量控制和熔断降级逻辑:
@SentinelResource(value = "createOrder")
@Override
public Order createOrder(Long productId, Long userId) {
    Product product = getProductFromRemoteWithLoadBalanceAnnotation(productId);

    // 使用 Feign 完成远程调用
    Product product = productFeignClient.getProductById(productId);
    Order order = new Order();
    order.setId(1L);
    
    // 总金额
    order.setTotalAmount(product.getPrice().multiply(new BigDecimal(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Xwzzz_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值