微服务架构:基于nacos配置中心的Sentinel配置保存技术实现

本文介绍了如何实现基于Nacos配置中心的Sentinel配置保存技术,包括搭建Nacos配置中心、启动Sentinel、主动拉取与实时监听Nacos规则、规则加载及测试验证。通过Nacos实现Sentinel规则的动态管理和持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      在上一篇博客《微服务架构:基于sentinel的限流、降级、监控》中,博主已经提到每次重启Sentinel之后,配置规则都会被清空,所以需要我们解决如何保存配置规则的问题。这个问题的解决方案通常有两种:

  • 修改Sentinel dashboard源码,集成nacos[1-3];
  • Sentinel集成Nacos实现动态流控规则[4-6]。

       博主对这两种方案都进行了尝试,方案一要改动Sentinel dashboard的大量代码,后期升级Sentinel时,又得重新改一遍,代价有点高,所以没有采用该方案。对于方案二,博主基于 sentinel1.8.2版本,一直没有尝试成功,不知道哪里出了问题,而且规则下发自己无法把控。因此,博主决定自己手撸基于nacos配置中心的Sentinel配置保存技术方案。技术实现思路大致如下:

1)实现nacos配置中心,在nacos后台配置sentinel规则;

2)主动拉取规则:启动服务器时,主动来取一次nacos后台配置规则;

3)实时接收规则:开启nacos配置实时监听,接收最新的nacos后台配置规则;

4)解析并加载规则:通过FlowRuleManager、DegradeRuleManager提供的API重新加载配置规则。

本文的提纲如下:

图1 博客提纲

   一.准备工作

       2.1 搭建配置中心

            首先,我们要搭建nacos配置中心。如果小伙伴还不了解nacos配置中心,请先阅读博主的文章《微服务架构: nacos配置中心的实现》,这里就不讲述nacos配置中心的搭建了。下面讲解配置中心重要部分的内容。

1)在nacos创建sentinel规则文件。

图1.1 创建sentinel规则文件

bootstrap.yml中对应的配置如下:

  cloud:
    nacos:
      config: # nacos 配置中心
        server-addr: localhost:8848
        file-extension: yaml # 配置文件格式是yml
        prefix: sentinel # 配置文件前缀
        group: DEFAULT_GROUP # group是默认的话,可以不写
        # dataID不用配置:,只需要在nacos后台将dataId命名为: ${prefix}-${spring.profile.active}.${file-extension}
        #;例如:sentinel-dev.yaml
      discovery: # 注册到nacos
        server-addr: localhost:8848

  profiles:
    active: dev

sentinel-dev.yml的详情:

图1.2 sentinel-dev.yaml详情

 1.2 启动sentinel

1.2.1 下载sentinel-dashboard.jar

       请到git下载sentinel-dashboard.jar最新版本:jar包下载地址。博主用的是sentinel-dashboard-1.8.2.jar版本。

图1.3 下载sentinel-dashboard.jar

 
1.2.2 启动sentinel

在终端输入:


 java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.2.jar


 其中: -Dserver.port=8080 用于指定 Sentinel 控制台端口为 8080。

   二.Sentinel配置规则获取

       2.1 启动主动拉取nacos配置中心配置的规则

&nbs

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值