当前位置:首页 > 科技  > 软件

改造Sentinel源码,实现Nacos双向通信!

来源: 责编: 时间:2023-10-17 18:04:57 255观看
导读Sentinel Dashboard(控制台)默认情况下,只能将配置规则保存到内存中,这样就会导致 Sentinel Dashboard 重启后配置规则丢失的情况,因此我们需要将规则保存到某种数据源中,Sentinel 支持的数据源有以下这些:图片然而,默认情况

Sentinel Dashboard(控制台)默认情况下,只能将配置规则保存到内存中,这样就会导致 Sentinel Dashboard 重启后配置规则丢失的情况,因此我们需要将规则保存到某种数据源中,Sentinel 支持的数据源有以下这些:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

然而,默认情况下,Sentinel 和数据源之间的关系是单向数据通讯的,也就是只能先在数据源中配置规则,然后数据源会被规则推送至 Sentinel Dashboard 和 Sentinel 客户端,但是在 Sentinel Dashboard 中修改规则或新增规则是不能反向同步到数据源中的,这就是单向通讯。5Aq28资讯网——每日最新资讯28at.com

所以,今天我们就该修改一下 Sentinel 的源码,让其可以同步规则至数据源,改造之后的交互流程如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

Sentinel 同步规则至数据源,例如将 Sentinel 的规则,同步规则至 Nacos 数据源的改造步骤很多,但整体实现难度不大,下面我们一起来看吧。5Aq28资讯网——每日最新资讯28at.com

1.下载Sentinel源码

下载地址:https://github.com/alibaba/Sentinel5Aq28资讯网——每日最新资讯28at.com

PS:本文 Sentinel 使用的版本是 1.8.6。5Aq28资讯网——每日最新资讯28at.com

下载源码之后,使用 idea 打开里面的 sentinel-dashboard 项目,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

2.修改pom.xml

将 sentinel-datasource-nacos 底下的 scope 注释掉,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

PS:因为官方提供的 Nacos 持久化实例,是在 test 目录下进行单元测试的,而我们是用于生产环境,所以需要将 scope 中的 test 去掉。5Aq28资讯网——每日最新资讯28at.com

3.移动单元测试代码

将 test/com.alibaba.csp.sentinel.dashboard.rule.nacos 下所有文件复制到 src/main/java/com.alibaba.csp.sentinel.dashboard.rule 目录下,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

4.新建NacosPropertiesConfiguration文件

在 com.alibaba.csp.sentinel.dashboard.rule 下创建 Nacos 配置文件的读取类,实现代码如下:5Aq28资讯网——每日最新资讯28at.com

package com.alibaba.csp.sentinel.dashboard.rule;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Configuration;@ConfigurationProperties(prefix = "sentinel.nacos")@Configurationpublic class NacosPropertiesConfiguration {    private String serverAddr;    private String dataId;    private String groupId;    private String namespace;    private String username;    private String password;    // 省略 Getter/Setter 代码}

5.修改NacosConfig文件

只修改 NacosConfig 中的 nacosConfigService 方法,修改后的代码如下:5Aq28资讯网——每日最新资讯28at.com

@Beanpublic ConfigService nacosConfigService(NacosPropertiesConfiguration nacosPropertiesConfiguration) throws Exception {    Properties properties = new Properties();    properties.put(PropertyKeyConst.SERVER_ADDR, nacosPropertiesConfiguration.getServerAddr());    properties.put(PropertyKeyConst.NAMESPACE, nacosPropertiesConfiguration.getNamespace());    properties.put(PropertyKeyConst.USERNAME,nacosPropertiesConfiguration.getUsername());    properties.put(PropertyKeyConst.PASSWORD,nacosPropertiesConfiguration.getPassword());    return ConfigFactory.createConfigService(properties);//        return ConfigFactory.createConfigService("localhost"); // 原代码}

6.修改FlowControllerV2文件

修改 com.alibaba.csp.sentinel.dashboard.controller.v2 目录下的 FlowControllerV2 文件:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

修改后代码:5Aq28资讯网——每日最新资讯28at.com

@Autowired@Qualifier("flowRuleNacosProvider")private DynamicRuleProvider<List<FlowRuleEntity>> ruleProvider;@Autowired@Qualifier("flowRuleNacosPublisher")private DynamicRulePublisher<List<FlowRuleEntity>> rulePublisher;

5Aq28资讯网——每日最新资讯28at.com

PS:此操作的目的是开启 Controller 层操作 Nacos 的开关。5Aq28资讯网——每日最新资讯28at.com

如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

7.修改配置信息

在 application.properties 中设置 Nacos 连接信息,配置如下:5Aq28资讯网——每日最新资讯28at.com

sentinel.nacos.serverAddr=localhost:8848sentinel.nacos.username=nacossentinel.nacos.password=nacossentinel.nacos.namespace=sentinel.nacos.groupId=DEFAULT_GROUPsentinel.nacos.dataId=sentinel-dashboard-demo-sentinel

8.修改sidebar.html

修改 webapp/resources/app/scripts/directives/sidebar/sidebar.html 文件:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

搜索“dashboard.flowV1”改为“dashboard.flow”,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

9.修改identity.js

identity.js 文件有两处修改,它位于 webapp/resources/app/scripts/controllers/identity.js 目录。5Aq28资讯网——每日最新资讯28at.com

9.1 第一处修改

将“FlowServiceV1”修改为“FlowServiceV2”,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

9.2 第二处修改

搜索“/dashboard/flow/”修改为“/dashboard/v2/flow/”,如下图所示:5Aq28资讯网——每日最新资讯28at.com

图片图片5Aq28资讯网——每日最新资讯28at.com

PS:修改 identity.js 文件主要是用于在 Sentinel 点击资源的“流控”按钮添加规则后将信息同步给 Nacos。5Aq28资讯网——每日最新资讯28at.com

小结

Sentinel Dashboard 默认情况下,只能将配置规则保存到内存中,这样就会程序重启后配置规则丢失的情况,因此我们需要给 Sentinel 设置一个数据源,并且要和数据源之间实现双向通讯,所以我们需要修改 Sentinel 的源码。源码的改造步骤虽然很多,但只要逐一核对和修改就可以实现 Sentinel 生成环境的配置了。看完记得收藏哦,防止以后用的时候找不到。5Aq28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-13673-0.html改造Sentinel源码,实现Nacos双向通信!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 7个开发者不可不知的VS Code小技巧

下一篇: 使用Python处理大型CSV文件

标签:
  • 热门焦点
  • 卢伟冰长文解析K60至尊版 对Redmi有着里程碑式的意义

    卢伟冰长文解析K60至尊版 对Redmi有着里程碑式的意义

    在今天的Redmi后性能时代战略发布会结束之后,Redmi总经理卢伟冰又带来了一篇长文,详解了为什么 Redmi 要开启后性能时代?为什么选择和 MediaTek、Pixelworks 深度合作?以及后性
  • 分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    1、OfficePLUSOfficePLUS网站旨在为全球Office用户提供丰富的高品质原创PPT模板、实用文档、数据图表及个性化定制服务。优点:OfficePLUS是微软官方网站,囊括PPT模板、Word模
  • 之家push系统迭代之路

    之家push系统迭代之路

    前言在这个信息爆炸的互联网时代,能够及时准确获取信息是当今社会要解决的关键问题之一。随着之家用户体量和内容规模的不断增大,传统的靠"主动拉"获取信息的方式已不能满足用
  • 在线图片编辑器,支持PSD解析、AI抠图等

    在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    在 Elasticsearch 中,function_score 可以让我们在查询的同时对搜索结果进行自定义评分。function_score 提供了一系列的参数和函数让我们可以根据需求灵活地进行设置。近期
  • Temu起诉SHEIN,跨境电商战事升级

    Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 自律,给不了Keep自由!

    自律,给不了Keep自由!

    来源 | 互联网品牌官作者 | 李大为编排 | 又耳 审核 | 谷晓辉自律能不能给用户自由暂时不好说,但大概率不能给Keep自由。近日,全球最大的在线健身平台Keep正式登陆港交所,努力
  • iQOO 11S新品发布会

    iQOO 11S新品发布会

    iQOO将在7月4日19:00举行新品发布会,推出杭州亚运会电竞赛事官方用机iQOO 11S。
  • 与兆芯合作  联想推出全新旗舰版笔记本电脑开天N7系列

    与兆芯合作 联想推出全新旗舰版笔记本电脑开天N7系列

    联想与兆芯合作推出全新联想旗舰版笔记本电脑开天 N7系列。这个系列采用兆芯KX-6640MA处理器平台,KX-6640MA 处理器是采用了陆家嘴架构,16nm 工艺,4 核 4 线
Top