Sentinel结合Nacos实现数据持久化过程详解

 更新时间:2023年05月20日 09:48:51   作者:小白的救赎  
这篇文章主要介绍了Sentinel结合Nacos实现数据持久化过程,要持久化的原因是因为每次启动Sentinel都会使之前配置的规则就清空了,这样每次都要再去设定规则显得非常的麻烦,感兴趣想要详细了解可以参考下文

前面学习完Sentinel的流控规则以及Nacos时,就是最后的Sentinel持久化了。

思路就是:将流控规则配置进Nacos服务注册中心中,这样每次启动Sentinel无需配置规则就有规则,但前提是启动完Sentinel后要先进入方法才看得到规则,因为Sentinel是懒加载机制。

一、引入依赖

<!--SpringCloud Alibaba Sentinel-datasource-nacos 持久化技术-->
<dependency>
    <groupId>com.alibaba.csp</groupId>
    <artifactId>sentinel-datasource-nacos</artifactId>
    <version>1.8.1</version>
</dependency>

二、启动类注解

@SpringBootApplication
@EnableDiscoveryClient
public class CloudAlibabaSentinelService {
    public static void main(String[] args) {
        SpringApplication.run(CloudAlibabaSentinelService.class, args);
    }
}

三、改yml

server:
  port: 8401
spring:
  application:
    name: cloud-sentinel-service
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服务注册中心地址
    sentinel:
      transport:
        dashboard: localhost:8080 #配置 dashboard监控平台地址
        port: 8719 #默认8719端口 如果被占用就自增直至找到未被占用的端口
      datasource:
        ds1:
          nacos:
            server-addr: localhost:8848
            dataId: ${spring.application.name}
            groupId: DEFAULT_GROUP
            data-type: json
            rule-type: flow     
#暴露监控断点
management:
  endpoint:
    sentinel:
      enabled: true
  endpoints:
    web:
      exposure:
        include: '*'

四、写控制层逻辑

@RestController
public class SentinelController {
    @GetMapping("/persistence")
    @SentinelResource("persistence")
    public R persistence(){
        return new R(200,"持久化测试正常",new Payment(2022L,"testPersistence"));
    }
}

五、Nacos

在Java启动后登录Nacos网页可以看到服务列表已经出现刚刚写的spring.application.name

在配置列表中配置我们需要的信息。

关于JSON中的信息具体含义如下:

resource:资源名称;

limitApp:来源应用;

grade:阈值类型;0表示线程数,1表示QPS;

count:单机阈值;

strategy:流控模式;0表示直接,1表示关联,2表示链路;

controlBehavior:流控效果;0表示快速失败,1表示Warm Up,2表示排队等待;

clusterMode:是否集群。

六、Sentinel

登录Sentinel页面刷新会发现有spring.application.name,但里面空空如也。

因为Sentinel是懒加载机制,所以这时候通过网址调用我们控制层的方法。

这时候回来Sentinel监控平台上刷新就能看到流控规则,正像Nacos中配置的JSON格式一样。

到这里就证明Sentinel持久化成功了

到此这篇关于Sentinel结合Nacos实现数据持久化过程详解的文章就介绍到这了,更多相关Sentinel结合Nacos内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈Java的LinkedHashSet源码

    浅谈Java的LinkedHashSet源码

    这篇文章主要介绍了浅谈Java的LinkedHashSet源码,底层是链表实现的,是set集合中唯一一个能保证怎么存就怎么取的集合对象
    因为是HashSet的子类,所以也是保证元素唯一的,与HashSet的原理一样,需要的朋友可以参考下
    2023-09-09
  • java实现图形卡片排序游戏

    java实现图形卡片排序游戏

    这篇文章主要为大家详细介绍了java实现图形卡片排序游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • 详解Java中的 枚举与泛型

    详解Java中的 枚举与泛型

    这篇文章主要介绍了 详解Java中的 枚举与泛型的相关资料,需要的朋友可以参考下
    2017-03-03
  • SpringBoot启动应用及回调监听原理解析

    SpringBoot启动应用及回调监听原理解析

    这篇文章主要介绍了SpringBoot启动应用及回调监听原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 详解springboot热启动与热部署

    详解springboot热启动与热部署

    本篇文章主要介绍了详解springboot热启动与热部署,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Java中操作超大数的方法

    Java中操作超大数的方法

    本篇文章是小编在网上整理的关于java操作超大数的方法以及解决思路,有兴趣的朋友参考学习下。
    2018-06-06
  • Java实现查找算法的示例代码(二分查找、插值查找、斐波那契查找)

    Java实现查找算法的示例代码(二分查找、插值查找、斐波那契查找)

    查找就是根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素。本文介绍了常见的数据查找算法:顺序查找、二分查找、插值查找和斐波那契查找等以及相应的Java代码实现。需要的可以参考一下
    2022-01-01
  • 关于@Transactional事务嵌套使用方式

    关于@Transactional事务嵌套使用方式

    Spring框架通过@Transactional注解来管理事务,它可以作用于类和方法上,用于声明事务的属性,如传播行为、隔离级别、超时时间等,Spring事务是基于AOP实现的,它在运行时为加了@Transactional注解的方法或类创建代理
    2024-11-11
  • springboot3.X 无法解析parameter参数问题分析

    springboot3.X 无法解析parameter参数问题分析

    本文介绍了Spring Boot 3.2.1版本中调用接口时出现的参数解析问题,该错误是由Spring新版本加强的错误校验和报错提示导致的,在Spring 6.1之后,官方要求URL中的传参必须使用`@PathVariable`声明用于接收的变量,而不能省略`@RequestParam`注解,感兴趣的朋友一起看看吧
    2025-03-03
  • Java动态数组添加数据的方法与应用示例

    Java动态数组添加数据的方法与应用示例

    这篇文章主要介绍了Java动态数组添加数据的方法,结合实例形式详细分析了Java动态数组的创建、添加、查找、打印等相关操作技巧,需要的朋友可以参考下
    2019-11-11

最新评论