成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Sentinel-Go 源碼之一開篇之作

開發(fā) 后端
本次選擇了 Sentinel-Go,一是對 Java 版本的 Sentinel 算是有一些了解,也在生產(chǎn)上落地過,二是感覺他的代碼應(yīng)該不會太復(fù)雜(僅僅是感覺),三是在云原生越來越熱的趨勢下,用 Go 實現(xiàn)的限流降級容錯應(yīng)該是比較通用的。

[[429705]]

本文轉(zhuǎn)載自微信公眾號「捉蟲大師」,作者捉蟲大師。轉(zhuǎn)載本文請聯(lián)系捉蟲大師公眾號。

大家好呀,打算寫一個 Go 語言組件源碼分析系列,一是為了能學(xué)習下 Go 語言,看下別人是怎么寫 Go 的,二是也掌握一個組件。

本次選擇了 Sentinel-Go,一是對 Java 版本的 Sentinel 算是有一些了解,也在生產(chǎn)上落地過,二是感覺他的代碼應(yīng)該不會太復(fù)雜(僅僅是感覺),三是在云原生越來越熱的趨勢下,用 Go 實現(xiàn)的限流降級容錯應(yīng)該是比較通用的。

源碼閱讀本身是枯燥的,我盡量用容易理解的語言來描述,希望大家也多支持我的文章,點個贊、在看和關(guān)注就是對我最大的支持。

背景

Sentinel 簡介

隨著微服務(wù)的流行,服務(wù)和服務(wù)之間的穩(wěn)定性變得越來越重要。Sentinel 是面向分布式服務(wù)架構(gòu)的流量控制組件,主要以流量為切入點,從流量控制、熔斷降級、系統(tǒng)自適應(yīng)保護等多個維度來幫助您保障微服務(wù)的穩(wěn)定性。

Sentinel 是阿里2018年開源的項目,最初是 Java 版本,截止目前有 17.6k 的star,項目地址為

https://github.com/alibaba/Sentinel/

2020年又開源了 Go 的版本,目的是朝云原生方向演進,截止目前 1.7k star,項目地址為

https://github.com/alibaba/sentinel-golang

Sentinel 的作用

在上面簡介中也說了,Sentinel 是微服務(wù)時代保障穩(wěn)定的神兵利器

舉個例子:電商系統(tǒng)中用戶瀏覽商品詳情頁,通常會通過 RPC 調(diào)用多個微服務(wù),查詢商品信息的同時還會查詢用戶的信息,也會展示優(yōu)惠信息,通常下拉列表還會展示推薦,廣告等信息,如下圖

如果流量較大時,CouponService 容量不足,或者某種原因?qū)е?RecomService 不可用,此時 AggrService 會被拖死,導(dǎo)致商品詳情服務(wù)不可用,但仔細想想這些服務(wù)不是那么重要,可以進行限流或者直接降級(不再調(diào)用),總比直接服務(wù)不用要好吧

又或者流量實在太高,ProductService 也頂不住了,那是否可以采取限流措施,保住部分用戶的請求是正常的,也比全部不可用要好

這些問題,Sentinel 都能解決

Sentinel 提供的能力

Sentinel 將要保護的對象(可以是某個服務(wù)或一段代碼)抽象為資源,通過動態(tài)下發(fā)的規(guī)則,對資源進行

  • 流量控制
  • 熔斷降級

針對這兩個主要功能又有很多的玩法,比如限流是針對QPS還是并發(fā)數(shù),控制的效果是直接拒絕還是排隊等等。

當然 Sentinel 也提供一個開箱即用的 Dashboard,可擴展配中心進行下發(fā)規(guī)則,展示監(jiān)控指標,調(diào)用關(guān)系鏈等等

快速開始

源碼閱讀環(huán)境準備

  • fork 源碼到自己倉庫,便于增加注釋
  • 拉取源碼到本地

git clone git@github.com:lkxiaolou/sentinel-golang.git

  • 導(dǎo)入 IDE,由于我既要寫 Java 又要寫 Go,所以用 IntelliJ IDEA 比較方便,只要裝一個 Go plugin 就可以了
  • 導(dǎo)入后,一般 IDE 會自動下載依賴,如果沒有自動下載,試試執(zhí)行( Go 安裝就不說了)

go mod download

目錄結(jié)構(gòu)介紹

  • sentinel-golang
    • api:對外暴露的接口
    • core:核心實現(xiàn)
    • example:使用例子
    • exporter:Prometheus的exporter
    • ext:擴展接口,主要是動態(tài)規(guī)則配置中心擴展接口
    • logging:日志模塊
    • pkg:第三方插件的實現(xiàn),比如各個組件適用 Sentinel 的 adapter,以及 Sentinel 對接各種第三方配置中心的擴展實現(xiàn)
    • tests:測試類代碼,包括單元測試、benchmark
    • util:工具類

樣例跑通

在 /example 目錄下新建 mytests 目錄,并創(chuàng)建一個 quick_start.go 文件,按照官網(wǎng)給出的例子,先用最簡單的默認方式初始化

  1. if err := sentinel.InitDefault(); err != nil { 
  2.  // 初始化失敗 
  3.  panic(err.Error()) 

再用寫死的方式加載規(guī)則

  1. // 資源名 
  2. resource := "test-resource" 
  3.  
  4. // 加載流控規(guī)則,寫死 
  5. _, err := flow.LoadRules([]*flow.Rule
  6.  { 
  7.   Resource: resource, 
  8.   // Threshold + StatIntervalInMs 可組合出多長時間限制通過多少請求,這里相當于限制為 10 qps 
  9.   Threshold: 10, 
  10.   StatIntervalInMs: 1000, 
  11.   // 暫時不用關(guān)注這些參數(shù) 
  12.   TokenCalculateStrategy: flow.Direct, 
  13.   ControlBehavior: flow.Reject, 
  14.  }, 
  15. }) 

最后寫測試代碼

  1. // 修改這個看看效果吧 
  2. currency := 100 
  3.  
  4. for i := 0; i < currency; i++ { 
  5.  go func() { 
  6.   e, b := sentinel.Entry(resource, sentinel.WithTrafficType(base.Inbound)) 
  7.   if b != nil { 
  8.    // 被流控 
  9.    fmt.Printf("blocked %s \n", b.BlockMsg()) 
  10.   } else { 
  11.    // 通過 
  12.    fmt.Println("pass..."
  13.    // 通過后必須調(diào)用Exit 
  14.    e.Exit() 
  15.   } 
  16.  }() 

這里限制了 10 qps,我們用 100 個協(xié)程并發(fā)測試跑一下,剛好通過10個請求

測試代碼已上傳到我的倉庫

https://github.com/lkxiaolou/sentinel-golang/tree/master/example/mytests

總結(jié)

 

本文介紹了 Sentinel 的和它能解決的問題,以及源碼閱讀的一些準備工作,并跑通了一個最簡單的例子,見識到了 Sentinel 限流的效果,本文先到這里,我們下一節(jié)見。

 

責任編輯:武曉燕 來源: 捉蟲大師
相關(guān)推薦

2012-09-20 10:07:29

Nginx源碼分析Web服務(wù)器

2021-09-22 07:57:23

Vue3 插件Vue應(yīng)用

2021-11-06 19:52:20

源碼ReadThread

2020-07-13 09:09:23

Sentinel源碼Bucket

2021-09-26 05:05:46

GoFiber Express

2010-02-25 11:18:02

C++

2021-05-20 08:59:47

Go調(diào)度本質(zhì)

2021-12-03 07:59:21

Go語言進程

2022-11-27 23:37:34

Go模式Workspaces

2023-10-17 17:13:14

內(nèi)存程序源碼

2022-12-14 23:05:29

Go模糊測試

2021-11-05 15:00:33

鴻蒙HarmonyOS應(yīng)用

2021-07-08 09:21:17

ZooKeeper分布式鎖 Curator

2021-06-27 21:24:55

RedissonJava數(shù)據(jù)

2017-05-15 21:20:36

2010-02-25 11:24:02

變量

2021-01-26 10:59:52

開源技術(shù) 數(shù)據(jù)

2024-11-13 10:16:37

2020-11-25 12:50:53

微軟老舊照片開源

2022-09-30 09:24:27

開源模型
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 黄色a视频 | 亚洲精品中文在线 | 亚洲国产精久久久久久久 | 成人久久一区 | 美美女高清毛片视频免费观看 | 欧美日韩黄色一级片 | 99久久婷婷国产综合精品电影 | 久久999| 成人免费视频观看 | 欧美精品福利视频 | 国产成人一区二区 | 中文字幕在线一区 | 夜操| 北条麻妃一区二区三区在线视频 | 日韩精品免费视频 | 国产亚洲欧美在线 | 日韩精品极品视频在线观看免费 | 国产精品亚洲精品久久 | 99国产视频 | 日韩一区二区三区在线 | 天堂久久网| 精品久久久久久久 | 国产成人福利在线观看 | 日韩在线观看网站 | 久草精品视频 | 国产精品呻吟久久av凹凸 | 亚洲视频在线观看 | 夜夜爽99久久国产综合精品女不卡 | 久久成人一区二区三区 | 国产精品美女久久久久久免费 | 操网站 | 欧美一区永久视频免费观看 | 久久久久国 | 亚洲欧洲精品在线 | 久久成人av | 在线观看av网站永久 | 国产精品一区二区三区久久 | 天堂av在线影院 | 中国一级大黄大片 | 精品一区二区久久久久久久网站 | 亚洲成人福利在线观看 |