Java中的Sentinel规则持久化详解

 更新时间:2023年09月12日 09:44:08   作者:小钟要学习!!!  
这篇文章主要介绍了Java中的Sentinel规则持久化详解,将限流配置规则持久化进Nacos保存,只要刷新8401某个rest地址,sentinel控制台的流控规则就能看到,只要Nacos里面的配置不删除,针对8401上sentinel上的流控规则持续有效,需要的朋友可以参考下

Sentinel规则持久化

根据之前遇到的问题可以看出,当服务关闭后Sentinel就不会再有对应的信息,也就是临时保存的,下面就是要进行持久化的保存

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

1、修改cloudalibaba-sentinel-service8401模块

1.1、引入pom.xml依赖

<!--SpringCloud ailibaba sentinel-datasource-nacos -->
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-datasource-nacos</artifactId>
</dependency>

1.2、修改YAML配置文件

server:
  port: 8401
spring:
  application:
    name: cloudalibaba-sentinel-service
  cloud:
    nacos:
      discovery:
        #Nacos服务注册中心地址
        server-addr: localhost:8848
    sentinel:
      transport:
        #配置Sentinel dashboard地址,8080监控8401
        dashboard: localhost:8080
        #默认8719端口,假如被占用会自动从8719开始依次+1扫描,直至找到未被占用的端口
        port: 8719
      datasource: # 持久化保存到nacos中
        ds1:
          nacos:
            server-addr: localhost:8848
            dataId: cloudalibaba-sentinel-service
            groupId: DEFAULT_GROUP
            data-type: json
            rule-type: flow
# 图像化展示,暴露所有端口
management:
  endpoints:
    web:
      exposure:
        include: '*'

2、添加Nacos业务规则配置

[
    {
        "resource": "/rateLimit/byUrl", // --------资源名称
        "limitApp": "default", // --------来源应用
        "grade": 1, // ------ 阈值类型,0表示线程数,1表示QPS
        "count": 1, // ------ 单机阈值
        "strategy": 0, // ------- 流控模式,0表示直接,1表示关联,2表示链路
        "controlBehavior": 0, // -------- 流控效果,0表示快速失败,1表示Warm Up,2表示排队等待;
        "clusterMode": false // 是否集群。
    }
]

在这里插入图片描述

3、重启8401测试

  1. 访问://localhost:8401/rateLimit/byUrl
  2. 查看Sentinel控制台是否有流控规则

在这里插入图片描述

  1. 关闭8401访问,流控规则消失
  2. 再次重启访问,并请求一次被Sentinel监控到流控规则出现

到此这篇关于Java中的Sentinel规则持久化详解的文章就介绍到这了,更多相关Sentinel规则持久化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决springboot 部署到 weblogic 中 jar 包冲突的问题

    解决springboot 部署到 weblogic 中 jar 包冲突的问题

    这篇文章主要介绍了springboot 部署到 weblogic 中 jar 包冲突,weblogic 也有是解决方案的,可以通过新增并配置 weblogic.xml 文件来定义哪些类需要优先从项目工程包的 jar 包中加载,本文给大家分享解决方法,需要的朋友可以参考下
    2022-08-08
  • 浅谈java多线程编程

    浅谈java多线程编程

    这篇文章主要介绍了java多线程编程的相关资料,文中讲解非常细致,帮助大家更好的理解和学习java多线程,感兴趣的朋友可以了解下
    2020-08-08
  • 详解如何在SpringBoot中实现优雅关闭

    详解如何在SpringBoot中实现优雅关闭

    这篇文章主要介绍了如何在SpringBoot中实现优雅关闭,SpringBoot应用程序的关闭可以是崩溃,也可以是手动关闭的,Shutdown、Crash 和 Graceful 之间的区别在于,它控制决定了我们可以用这个事件做什么,本文中,一起研究下Spring Boot提供的开箱即用功能之一:优雅关闭
    2024-09-09
  • spring基础系列之JavaConfig配置详解

    spring基础系列之JavaConfig配置详解

    本篇文章主要介绍了spring基础系列之JavaConfig配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • java中的FileInputStream(输入流)

    java中的FileInputStream(输入流)

    这篇文章主要介绍了java中的FileInputStream(输入流),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • 如何配置Eclipse实现定制登录界面

    如何配置Eclipse实现定制登录界面

    本文介绍了如何配置Eclipse实现定制登录界面,每一步的讲解都很细致,感兴趣的小伙伴可以阅读一下
    2015-07-07
  • SpringCloud 微服务数据权限控制的实现

    SpringCloud 微服务数据权限控制的实现

    这篇文章主要介绍的是权限控制的数据权限层面,意思是控制可访问数据资源的数量,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-11-11
  • Maven中引入 springboot 相关依赖的方式(最新推荐)

    Maven中引入 springboot 相关依赖的方式(最新推荐)

    这篇文章主要介绍了Maven中引入 springboot 相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-04-04
  • springboot vue测试平台接口定义及发送请求功能实现

    springboot vue测试平台接口定义及发送请求功能实现

    这篇文章主要为大家介绍了springboot+vue测试平台接口定义及发送请求功能实现,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • 一篇文章带你了解Maven的生命周期

    一篇文章带你了解Maven的生命周期

    这篇文章主要为大家介绍了Maven的生命周期 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01

最新评论