sentinel规则配置持久化

一、前言

1、官方在sentinel中也已经说了,sentinel用于生产环境,需要做一些自适应的改变,这是官方的一篇文章 在生产环境中使用 Sentinel,其中就有说到规则数据的持久化。具体详细细节我就不再说了。实现方式如下
sentinel规则配置持久化_第1张图片

二、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会立刻更新。
sentinel规则配置持久化_第2张图片
sentinel规则配置持久化_第3张图片
sentinel规则配置持久化_第4张图片
sentinel规则配置持久化_第5张图片

sentinel规则配置持久化_第6张图片
sentinel规则配置持久化_第7张图片

[
    {
        "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源码改造

这篇文章只是改造了一个规则(流控规则),如果你需要修改其他的规则,可以参考这个流程,但是不一定都一样,可能会有些微差别
sentinel规则配置持久化_第8张图片

3、这一篇文章里面改造了所有的规则(五种规则),在springCloud架构下实现sentinel持久化到nacos,大家可以参考下。

3、我是建议使用这种方式的,因为后面还有一些其他的地方都是要改sentinel dashboard源码的,比如自定义授权认证,增加RBAC的功能,监控页面只能展示近5分钟数据等等。不如提前看,了解其内部流程,方便后续的其他地方修改。

你可能感兴趣的:(java,生态圈,java,开发语言)