SpringCloud:微服务保护之规则持久化

现在,sentinel的所有规则都是内存存储,重启后所有规则都会丢失。在生产环境下,我们必须确保这些规则的持久化,避免丢失。

1.规则管理模式

规则是否能持久化,取决于规则管理模式,sentinel支持三种规则管理模式:

  • 原始模式:Sentinel的默认模式,将规则保存在内存,重启服务会丢失。
  • pull模式
  • push模式

1.1.pull模式

pull模式:控制台将配置的规则推送到Sentinel客户端,而客户端会将配置规则保存在本地文件或数据库中。以后会定时去本地文件或数据库中查询,更新本地规则。

在这里插入图片描述

1.2.push模式

push模式:控制台将配置规则推送到远程配置中心,例如NacosSentinel客户端监听Nacos,获取配置变更的推送消息,完成本地配置更新。

在这里插入图片描述

2.实现push模式

2.1.修改order-service服务

修改OrderService,让其监听Nacos中的sentinel规则配置。具体步骤如下:

2.1.1.引入依赖

order-service中引入sentinel监听nacos的依赖:

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-nacos</artifactId>
        </dependency>

2.1.2.配置nacos地址

order-service中的application.yml文件配置nacos地址及监听的配置信息:

spring:
  cloud:
    sentinel:
      datasource:
        flow:
          nacos:
            server-addr: localhost:8848 # nacos地址
            dataId: orderservice-flow-rules
            groupId: SENTINEL_GROUP
            rule-type: flow # 还可以是:degrade、authority、param-flow

2.2.修改sentinel-dashboard源码

SentinelDashboard默认不支持nacos的持久化,需要修改源码。

2.2.1. 下载、解压源码包

从官网中下载的sentinel源码包:

在这里插入图片描述

然后并用IDEA打开这个项目,结构如下:

在这里插入图片描述

2.2.2. 修改nacos依赖

sentinel-dashboard源码的pom文件中,nacos的依赖默认的scopetest,只能在测试时使用,这里要去除:

在这里插入图片描述

sentinel-datasource-nacos依赖的scope去掉:

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

2.2.3. 添加nacos支持

sentinel-dashboardtest包下,已经编写了对nacos的支持,我们需要将其拷贝到main下。

在这里插入图片描述

2.2.4. 修改nacos地址

然后,还需要修改测试代码中的NacosConfig类,修改其中的nacos地址,让其读取application.properties中的配置:

在这里插入图片描述

sentinel-dashboardapplication.properties中添加nacos地址配置:

nacos.addr=localhost:8848

2.2.5. 配置nacos数据源

另外,还需要修改com.alibaba.csp.sentinel.dashboard.controller.v2包下的FlowControllerV2类,让我们添加的Nacos数据源生效:

在这里插入图片描述

2.2.6. 修改前端页面

接下来,还要修改前端页面,添加一个支持nacos的菜单。修改src/main/webapp/resources/app/scripts/directives/sidebar/目录下的sidebar.html文件,将其中的这部分注释打开:

在这里插入图片描述

修改其中的文本:

在这里插入图片描述

2.2.7. 重新编译、打包项目

运行IDEA中的maven插件,编译和打包修改好的Sentinel-Dashboard

在这里插入图片描述

2.2.8.启动

启动方式跟官方一样:

java -jar sentinel-dashboard.jar

如果要修改nacos地址,需要添加参数:

java -jar -Dnacos.addr=localhost:8848 sentinel-dashboard.jar

猜你喜欢

转载自blog.csdn.net/qq_37726813/article/details/130674609
今日推荐