sentinel整合nacos持久化

yml网关配置,与nacos整合持久化sentinel

yml 复制代码
server:
  port: 9999

spring:
  application:
    name: demo-gateway
  main:
    allow-circular-references: true
  config:
    import:
      - optional:nacos:${spring.application.name}-@profile.name@.yaml
  cloud:
    nacos:
      config:
        server-addr: @config.server-addr@
        group: @config.group@
        namespace: @config.namespace@
        username: @config.username@
        password: @config.password@
      discovery:
        server-addr: ${spring.cloud.nacos.config.server-addr}
        group: @config.group@
        namespace: @config.namespace@
        username: @config.username@
        password: @config.password@
    gateway:
      discovery:
        locator:
          enabled: true
      globalcors:
        cors-configurations:
          '[/**]':
            allowCredentials: true
            #springboot2.4后需用allowedOriginPatterns
            allowedOriginPatterns: "*"
            allowedMethods: "*"
            allowedHeaders: "*"
    #Sentinel配置
    sentinel:
      transport:
        dashboard: 192.168.11.50:8858
      # 支持链路限流
      web-context-unify: false
      filter:
        enabled: false
      # 取消Sentinel控制台懒加载
      eager: false
      datasource:
        #流控规则
        flow:  # 指定数据源名称
          # 指定nacos数据源
          nacos:
            server-addr: @config.server-addr@
            # 指定配置文件
            dataId: ${spring.application.name}-flow-rules
            # 指定分组
            groupId: SENTINEL_GROUP
            # 指定配置文件规则类型
            rule-type: flow
            # 指定配置文件数据格式
            data-type: json
        #降级规则
        degrade:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-degrade-rules
            groupId: SENTINEL_GROUP
            rule-type: degrade
            data-type: json
        #系统规则
        system:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-system-rules
            groupId: SENTINEL_GROUP
            rule-type: system
            data-type: json
        #授权规则
        authority:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-authority-rules
            groupId: SENTINEL_GROUP
            rule-type: authority
            data-type: json
        #热点参数
        param-flow:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-param-rules
            groupId: SENTINEL_GROUP
            rule-type: param-flow
            data-type: json
        #网关流控规则
        gw-flow:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-flow-rules
            groupId: SENTINEL_GROUP
            rule-type: gw-flow
            data-type: json
        #API流控规则
        gw-api-group:
          nacos:
            server-addr: @config.server-addr@
            dataId: ${spring.application.name}-api-rules
            groupId: SENTINEL_GROUP
            rule-type: gw-api-group
            data-type: json

在nacos创建sentinel相应的规则

流控规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "limitApp": "default",
  "grade": 1,
  "count": 10,
  "strategy": 0,
  "controlBehavior": 0,
  "clusterMode": false
}

降级规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "grade": 1,
  "count": 10,
  "timeWindow": 10,
  "minRequestAmount": 5,
  "statIntervalMs": 5000
}

系统规则示例

bash 复制代码
{
  "highestCpuUsage": 0.8,
  "highestMemoryUsage": 0.8,
  "qps": 1000
}

授权规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "limitApp": "default",
  "strategy": 0,
  "resourceMode": 0,
  "warmUpPeriodSec": 10,
  "maxQueueingTimeMs": 500
}

热点参数流控规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "paramIdx": 0,
  "count": 10,
  "grade": 1,
  "paramFlowItemList": [
    {
      "object": "param_value_1",
      "count": 5
    },
    {
      "object": "param_value_2",
      "count": 5
    }
  ]
}

网关流控规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "limitApp": "default",
  "grade": 1,
  "count": 10,
  "strategy": 0,
  "controlBehavior": 0,
  "clusterMode": false
}

API 流控规则示例

bash 复制代码
{
  "resource": "your_resource_name",
  "limitApp": "default",
  "grade": 1,
  "count": 10,
  "strategy": 0,
  "controlBehavior": 0,
  "clusterMode": false
}

注意:这是模糊流控规则,其他模糊同理

bash 复制代码
{
  "resource": "/api/**", // 匹配所有以 /api/ 开头的路径,包括 /api/user、/api/order 等
  "limitApp": "default",
  "grade": 1,
  "count": 10,
  "strategy": 0,
  "controlBehavior": 0,
  "clusterMode": false
}
相关推荐
寻星探路2 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
陌上丨4 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
曹牧4 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
AI_56784 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw4 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30734 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道5 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
爬山算法5 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7255 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎5 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven