Sentinel結(jié)合Apollo實(shí)現(xiàn)規(guī)則持久化功能

概述:本文基于apollo熟練使用的小伙伴參考撕攒,因?yàn)楸疚臎](méi)有安裝啟動(dòng)apollo的步驟蒸苇,只提供apollo的對(duì)應(yīng)的appid和相應(yīng)的配置磷蛹,具體apollo部署及客戶端配置使用本文未提供,apollo相關(guān)依賴(lài)本文未提供溪烤;

本文使用:
spring-boot-2.6.8版本
spring-cloud-starter-alibaba-2021.0.1.0版本
sentinel-dashboard-1.8.3版本

一味咳、調(diào)整sentinel-dashboard源碼,調(diào)整步驟如下:

  1. 將test包中的apollo包移到rule包下面
  2. 將最外層pom文件中的sentinel-datasource-apollo依賴(lài)的范圍test注釋掉
  3. 修改apollo包下面的ApolloConfig類(lèi)檬嘀,修改apollo的地址和token (獲取apollotoken的方式在第"四"步)
  4. 修改apollo包下面的FlowRuleApolloProvider類(lèi)槽驶,修改apollo的appid和命名空間,都根據(jù)實(shí)際情況修改即可
  5. 修改apollo包下面的FlowRuleApolloPublisher類(lèi)枪眉,修改apollo的appid和命名空間,都根據(jù)實(shí)際情況修改即可
  6. 修改controller-v2包下面的FlowControllerV2類(lèi)再层,修改注入的規(guī)則了為apollo的

通過(guò)以上調(diào)整贸铜,sentinel-dashboard控制臺(tái)的包調(diào)整完成,重新打包部署就可以了聂受,下面展示apollo中的配置

移動(dòng)apollo包

注釋掉依賴(lài)的test

修改apollo地址和token

image.png

image.png

image.png

二蒿秦、apollo配置

spring.application.name = SentinelService
spring.cloud.sentinel.transport.dashboard = localhost:39999
spring.cloud.sentinel.log.dir = /logs

flowRules = [{"app":"SentinelService","clusterMode":false,"controlBehavior":0,"count":1,"gmtModified":1596855658214,"grade":1,"id":1,"limitApp":"default","resource":"/getMethod","strategy":0}]
degrades = [{"resource": "/getMethod","count": 50,"timeWindow": 5,"grade": 0},{"resource": "/getMethod","count": 5,"timeWindow": 8,"grade": 2},{"resource": "/erro","count": 0.5,"timeWindow": 5,"grade": 1}]
authoritys = [{"resource": "/getMethod","limitApp": "192.168.12.215","strategy": 1}]
paramflows = [{"resource": "/getMethod","grade": 1,"paramIdx": 1,"count": 10,"paramFlowItemList": []}]
systems = [{"qps": 20}]
image.png

image.png

三、客戶端服務(wù)配置

客戶端服務(wù)需添加的依賴(lài):
pom文件配置

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
            <version>2021.0.1.0</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba.csp</groupId>
            <artifactId>sentinel-datasource-apollo</artifactId>
           <version>1.8.3</version>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.csp</groupId>
                    <artifactId>sentinel-datasource-extension</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>com.alibaba.csp</groupId>
                    <artifactId>sentinel-core</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

yml文件配置

#Apollo配置
app:
  id: hse-backend2.0.0
apollo:
  meta: http://127.0.0.1:8080/
  bootstrap:
    enabled: true
    namespaces: sino-sentinel
env: dev

server:
  port: 39000

###應(yīng)用編碼配置
appCode: SentinelService

spring:
  application.name: SentinelService
  cloud:
    sentinel:
      log:
        dir: /logs
        switch-pid: true
      transport:
        dashboard: 127.0.0.1:39999
      datasource:
        flow: # 流控規(guī)則
          apollo:
            namespaceName: sino-sentinel
            flowRulesKey: flowRules
            rule-type: flow  #flow,degrade,authority,system, param-flow
        degrade: # 熔斷降級(jí)規(guī)則
          apollo:
            namespaceName: sino-sentinel
            flowRulesKey: degrades
            rule-type: degrade
        authority: # 授權(quán)規(guī)則  未驗(yàn)證,官方不推薦
          apollo:
            namespaceName: sino-sentinel
            flowRulesKey: authoritys
            rule-type: authority
        system: # 系統(tǒng)規(guī)則
          apollo:
            namespaceName: sino-sentinel
            flowRulesKey: systems
            rule-type: system
        param-flow: # 熱點(diǎn)規(guī)則
          apollo:
            namespaceName: sino-sentinel
            flowRulesKey: paramflows
            rule-type: param-flow
image.png

四蛋济、獲取apollo第三方接入的token

image.png

image.png

image.png

五棍鳖、查看結(jié)果

將sentinel控制臺(tái)啟動(dòng),apollo服務(wù)啟動(dòng)及配置完成碗旅,客戶端服務(wù)啟動(dòng)渡处。然后訪問(wèn)客戶端服務(wù)的接口,即可在sentinel控制臺(tái)看到對(duì)應(yīng)的接口訪問(wèn)數(shù)據(jù)祟辟,同時(shí)也可以看到對(duì)應(yīng)的流控規(guī)則等其他在apollo配置的規(guī)則医瘫,也在sentinel控制臺(tái)上展示出來(lái)了

image.png

image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市旧困,隨后出現(xiàn)的幾起案子醇份,更是在濱河造成了極大的恐慌,老刑警劉巖吼具,帶你破解...
    沈念sama閱讀 221,548評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件僚纷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡拗盒,警方通過(guò)查閱死者的電腦和手機(jī)怖竭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)陡蝇,“玉大人侵状,你說(shuō)我怎么就攤上這事赞弥。” “怎么了趣兄?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,990評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵绽左,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我艇潭,道長(zhǎng)拼窥,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,618評(píng)論 1 296
  • 正文 為了忘掉前任蹋凝,我火速辦了婚禮鲁纠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鳍寂。我一直安慰自己改含,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布迄汛。 她就那樣靜靜地躺著捍壤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鞍爱。 梳的紋絲不亂的頭發(fā)上鹃觉,一...
    開(kāi)封第一講書(shū)人閱讀 52,246評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音睹逃,去河邊找鬼盗扇。 笑死,一個(gè)胖子當(dāng)著我的面吹牛沉填,可吹牛的內(nèi)容都是我干的疗隶。 我是一名探鬼主播,決...
    沈念sama閱讀 40,819評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼翼闹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼抽减!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起橄碾,我...
    開(kāi)封第一講書(shū)人閱讀 39,725評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤卵沉,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后法牲,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體史汗,經(jīng)...
    沈念sama閱讀 46,268評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評(píng)論 3 340
  • 正文 我和宋清朗相戀三年拒垃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了停撞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,488評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖戈毒,靈堂內(nèi)的尸體忽然破棺而出艰猬,到底是詐尸還是另有隱情,我是刑警寧澤埋市,帶...
    沈念sama閱讀 36,181評(píng)論 5 350
  • 正文 年R本政府宣布冠桃,位于F島的核電站,受9級(jí)特大地震影響道宅,放射性物質(zhì)發(fā)生泄漏食听。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評(píng)論 3 333
  • 文/蒙蒙 一污茵、第九天 我趴在偏房一處隱蔽的房頂上張望樱报。 院中可真熱鬧,春花似錦泞当、人聲如沸迹蛤。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,331評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)盗飒。三九已至,卻和暖如春敌蜂,著一層夾襖步出監(jiān)牢的瞬間箩兽,已是汗流浹背津肛。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,445評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工章喉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人身坐。 一個(gè)月前我還...
    沈念sama閱讀 48,897評(píng)論 3 376
  • 正文 我出身青樓秸脱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親部蛇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子摊唇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容