SpringCloud Alibaba Sentinel规则持久化实践总结

默认情况下,一旦我们重启应用,sentinel规则将消失,生产环境需要将配置规则进行持久化。这里我们实践将Sentinel持久化到Nacos中。

① pom依赖

我们引入sentinel-datasource-nacos:

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- 持久化用到 -->
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-datasource-nacos</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

② yml配置

yml 复制代码
server:
  port: 8401

spring:
  application:
    name: cloud-alibaba-sentinel-service
  cloud:
    nacos:
      discovery:
        # 服务注册中心地址
        server-addr: localhost:8848
    sentinel:
      transport:
        # 配置sentinel dashboard地址
        dashboard: localhost:8080
        # 默认 8719端口,假如被占用从8719开始+1扫描直到直到未被占用的端口
        port: 8719
      datasource: # 规则持久化
        ds1:
          nacos:
            server-addr: localhost:8848 #nacos地址
            dataId: cloud-alibaba-sentinel-service  #微服务名称
            groupId: DEFAULT_GROUP  #默认分组
            data-type: json #数据格式
            rule-type: flow #流控规则
management:
  endpoints:
    web:
      exposure:
        include: '*'

③ Nacos添加配置

java 复制代码
resource:资源名称;
limitApp:来源应用;
grade:阈值类型,0表示线程数,1表示QPS;
count:单机阈值;
strategy:流控模式,0表示直接,1表示关联,2表示链路;
controlBehavior:流控效果,0表示快速失败,1表示Warm Up,2表示排队等待;
clusterMode:是否集群。

其实就是Sentinel控制台如下配置:

④ 测试

从Sentinel控制台删除规则,停掉服务实例8401,此时再刷新Sentinel控制台,规则是空的。

在将规则配置进Nacos后,启动8401,刷新Sentinel控制台,规则仍旧是空的。

浏览器访问 http://localhost:8401/rateLimit/byUrl ,刷新Sentinel控制台,规则出现:

(这里要稍等一会)多次请求访问 http://localhost:8401/rateLimit/byUrl ,出现流控管控情况:

相关推荐
i***58671 小时前
springcloud springboot nacos版本对应
spring boot·spring·spring cloud
q***16082 小时前
SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法
spring cloud·微服务·mybatis
小坏讲微服务10 小时前
Spring Cloud Alibaba 整合 Scala 教程完整使用
java·开发语言·分布式·spring cloud·sentinel·scala·后端开发
ruleslol1 天前
Spring Cloud: Sentinel入门讲解
spring cloud·sentinel
X***C8621 天前
使用bitnamiredis-sentinel部署Redis 哨兵模式
数据库·redis·sentinel
摇滚侠1 天前
2025最新 SpringCloud 教程,教程简介,笔记01
笔记·spring cloud
vx_vxbs661 天前
【SSM电动车智能充电服务平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·mysql·spring cloud·小程序·php·idea
踏浪无痕1 天前
@Transactional的5种失效场景和自检清单
spring boot·后端·spring cloud
小坏讲微服务1 天前
SpringCloud整合Scala实现MybatisPlus实现业务增删改查
java·spring·spring cloud·scala·mybatis plus
q***49861 天前
SpringCloud系列教程:微服务的未来 (五)枚举处理器、JSON处理器、分页插件实现
spring cloud·微服务·json