一、前言
1、官方在sentinel 中也已经说了,sentinel 用于生产环境,需要做一些自适应的改变,这是官方的一篇文章 在生产环境中使用 Sentinel,其中就有说到规则数据的持久化。具体详细细节我就不再说了。实现方式如下
二、Sentinel持久化 (本地和nacos)两种方法
1、对于文件和nacos的实现网上很多,但是都是一样的,这里用其中一篇文章说明 Sentinel持久化 (本地和nacos)两种方法,就不再细说了。
2、这里主要想做出一点解释,毕竟我一开始按照这些方法做完成后,可能和大家想的不一样。对于上面或者说网上提供的这种类似方式都不太完善,怎么说呢
- 用文件的方式,在你修改对应限流配置文件后,这个限流规则确实是生效了(加载到内存中了,代码里面有体现), 但是只能你在sentinel dashboard 的对应规则页面中,看到你在配置文件中增加或者修改的内容,但是你如果在sentinel dashboard 中修改的了限流规则,是不会同步到文件的。那这就很尴尬了,一旦你选择了持久化,sentinel dashboard 只能用来看了,不能用于页面配置了(即使用了,确实也能生效,但是你在dashboard 配置的,重启后又会失效了,真正持久话的是配置文件中的。)
- 对于使用nacos,其实也是一样,把上面那段话的文件配置换成 nacos,就行了,也是相同的问题,sentinel dasboard修改后,也无法同步到nacos。
- 所以以上两种方式,就是一旦你选择了其中一种,后续所有的持久化配置就在对应的方式里面写,比如文件或者nacos。
3、这里给出nacos的方式的示意图,当我们在nacos修改规则时候,你会发现 nacos dashboard 会立刻更新。
[
{
"resource":"/problem/page",
"controlBehavior":0,
"count":10,
"grade":1,
"limitApp":"default",
"strategy":0
},
{
"resource":"/problem/detail",
"controlBehavior":0,
"count":3,
"grade":1,
"limitApp":"default",
"strategy":0
}
]
[
{
"avgRt": 10,
"highestSystemLoad": 5.0,
"maxThread": 10,
"qps": 20.0
}
]
三、使用Sentinel Dashboard统一界面进行配置管理流控规则
1、所以综上所述,如果你希望达到一种完美的状态,即使用Sentinel Dashboard统一界面进行配置管理流控规则,你就得自己改造sentinel dashboard 的源码.
2、这里网上也有就不再多说了,可以参考 Sentinel Dashboard(基于1.8.1)流控规则持久化到Nacos——涉及部分Sentinel Dashboard源码改造
这篇文章只是改造了一个规则(流控规则),如果你需要修改其他的规则,可以参考这个流程,但是不一定都一样,可能会有些微差别
3、这一篇文章里面改造了所有的规则(五种规则),在springCloud架构下实现sentinel持久化到nacos,大家可以参考下。
3、我是建议使用这种方式的,因为后面还有一些其他的地方都是要改sentinel dashboard 源码的,比如自定义授权认证,增加RBAC的功能,监控页面只能展示近5分钟数据等等。不如提前看,了解其内部流程,方便后续的其他地方修改。
|