SpringCloudAlibaba——Sentinel持久化规则

Sentinel持久化规则

哪样的情况进行持久化设置? 一旦我们重启应用,sentinel规则将消失,生产环境需要将配置规则进行持久化。

持久化的思路: 将限流配置规则持久化进Nacos保存,只要刷新8401某个rest地址,sentinel控制台的流控规则就能看到,只要Nacos里面的配置不删除,针对8401上sentinel上的流控规则持续有效。

设置持久化规则的流程:

  1. 添加依赖:
<!--SpringCloud ailibaba sentinel-datasource-nacos 后续做持久化用到-->
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-nacos</artifactId>
        </dependency>
  1. 配置:application.yml
server:
  port: 8401

spring:
  application:
    name: cloudalibaba-sentinel-service
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
    sentinel:
      transport:
        dashboard: localhost:8080 #控制台
        port: 8719   #默认8719端口,假如被占用会自动从8719开始依次+1扫描,直至找到未被占用的端口
      datasource: #添加Nacos数据源配置
        ds1:
          nacos:
            server-addr: localhost:8848
            dataId: ${
          
   spring.application.name}
            groupId: DEFAULT_GROUP
            data-type: json
            rule-type: flow

management:
  endpoints:
    web:
      exposure:
        include: *

启动8401后,刷新sentinel控制台,发现业务规则已经加载: 测试,快速多次访问接口:流控规则生效 停止8401,再刷新sentinel:流控规则消失。 再次启动8401,刷新sentinel:流控规则加载成功

经验分享 程序员 微信小程序 职场和发展