在上一篇博客《微服务架构:基于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重新加载配置规则。
本文的提纲如下:
![](https://img-blog.csdnimg.cn/20210725104908949.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3Rvcm55TGlu,size_16,color_FFFFFF,t_70)
一.准备工作
2.1 搭建配置中心
首先,我们要搭建nacos配置中心。如果小伙伴还不了解nacos配置中心,请先阅读博主的文章《微服务架构: nacos配置中心的实现》,这里就不讲述nacos配置中心的搭建了。下面讲解配置中心重要部分的内容。
1)在nacos创建sentinel规则文件。
![](https://img-blog.csdnimg.cn/2021072510584632.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3Rvcm55TGlu,size_16,color_FFFFFF,t_70)
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的详情:
![](https://img-blog.csdnimg.cn/20210725110323804.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3Rvcm55TGlu,size_16,color_FFFFFF,t_70)
1.2 启动sentinel
1.2.1 下载sentinel-dashboard.jar
请到git下载sentinel-dashboard.jar最新版本:jar包下载地址。博主用的是sentinel-dashboard-1.8.2.jar版本。
![](https://img-blog.csdnimg.cn/20210724132931488.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3Rvcm55TGlu,size_16,color_FFFFFF,t_70)
1.2.2 启动sentinel
在终端输入:
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.2.