精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

優(yōu)化 Golang 分布式行情推送的性能瓶頸

開發(fā) 前端 分布式
最近一直在優(yōu)化行情推送系統(tǒng),有不少優(yōu)化心得跟大家分享下。性能方面提升最明顯的是時延,在單節(jié)點8萬客戶端時,時延從1500ms優(yōu)化到40ms,這里是內(nèi)網(wǎng)mock客戶端的得到的壓測數(shù)據(jù)。

[[409249]]

本文轉(zhuǎn)載自微信公眾號「碼農(nóng)桃花源」,作者峰云就她了 。轉(zhuǎn)載本文請聯(lián)系碼農(nóng)桃花源公眾號。

最近一直在優(yōu)化行情推送系統(tǒng),有不少優(yōu)化心得跟大家分享下。性能方面提升最明顯的是時延,在單節(jié)點8萬客戶端時,時延從1500ms優(yōu)化到40ms,這里是內(nèi)網(wǎng)mock客戶端的得到的壓測數(shù)據(jù)。

對于訂閱客戶端數(shù)沒有太執(zhí)著量級的測試,弱網(wǎng)絡(luò)下單機(jī)8w客戶端是沒問題的。當(dāng)前采用的是kubenetes部署方案,可靈活地擴(kuò)展擴(kuò)容。

架構(gòu)圖

push-gateway是推送的網(wǎng)關(guān),有這么幾個功能:第一點是為了做鑒權(quán);第二點是為了做接入多協(xié)議,我們這里實現(xiàn)了websocket, grpc, grpc-web,sse的支持;第三點是為了實現(xiàn)策略調(diào)度及親和綁定等。

push-server 是推送服務(wù),這里維護(hù)了訂閱關(guān)系及監(jiān)聽mq的新消息,繼而推送到網(wǎng)關(guān)。

問題一:并發(fā)操作map帶來的鎖競爭及時延

推送的服務(wù)需要維護(hù)訂閱關(guān)系,一般是用嵌套的map結(jié)構(gòu)來表示,這樣造成map并發(fā)競爭下帶來的鎖競爭和時延高的問題。

  1. // xiaorui.cc  
  2. {"topic1": {"uuid1": client1, "uuid2": client2}, "topic2": {"uuid3": client3,  "uuid4": client4}   ... }  

已經(jīng)根據(jù)業(yè)務(wù)拆分了4個map,但是該訂閱關(guān)系是嵌套的,直接上鎖會讓其他協(xié)程都阻塞,阻塞就會造成時延高。

加鎖操作map本應(yīng)該很快,為什么會阻塞?上面我們有說過該map是用來存topic和客戶端列表的訂閱關(guān)系,當(dāng)我進(jìn)行推送時,必然是需要拿到該topic的所有客戶端,然后進(jìn)行一個個的send通知。(這里的send不是io.send,而是chan send,每個客戶端都綁定了緩沖的chan)

解決方法:在每個業(yè)務(wù)里劃分256個map和讀寫鎖,這樣鎖的粒度降低到1/256。除了該方法,開始有嘗試過把客戶端列表放到一個新的slice里返回,但造成了 GC 的壓力,經(jīng)過測試不可取。

  1. // xiaorui.cc 
  2.  
  3. sync.RWMutex 
  4. map[string]map[string]client 
  5.  
  6. 改成這樣 
  7.  
  8. m *shardMap.shardMap 

分段map的庫已經(jīng)推到github[1]了,有興趣的可以看看。

問題二:串行消息通知改成并發(fā)模式

簡單說,我們在推送服務(wù)維護(hù)了某個topic和1w個客戶端chan的映射,當(dāng)從mq收到該topic消息后,再通知給這1w個客戶端chan。

客戶端的chan本身是有大buffer,另外發(fā)送的函數(shù)也使用 select default 來避免阻塞。但事實上這樣串行發(fā)送chan耗時不小。對于channel底層來說,需要goready等待channel的goroutine,推送到runq里。

下面是我寫的benchmark[2],可以對比串行和并發(fā)的耗時對比。在mac下效果不是太明顯,因為mac cpu頻率較高,在服務(wù)器里效果明顯。

串行通知,拿到所有客戶端的chan,然后進(jìn)行send發(fā)送。

  1. for _, notifier := range notifiers { 
  2.     s.directSendMesg(notifier, mesg) 

并發(fā)send,這里使用協(xié)程池來規(guī)避morestack的消耗,另外使用sync.waitgroup里實現(xiàn)異步下的等待。

  1. // xiaorui.cc 
  2.  
  3. notifiers := []*mapping.StreamNotifier{} 
  4. // conv slice 
  5. for _, notifier := range notifierMap { 
  6.     notifiers = append(notifiers, notifier) 
  7.  
  8.  
  9. // optimize: direct map struct 
  10. taskChunks := b.splitChunks(notifiers, batchChunkSize) 
  11.  
  12.  
  13. // concurrent send chan 
  14. wg := sync.WaitGroup{} 
  15. for _, chunk := range taskChunks { 
  16.     chunkCopy := chunk // slice replica 
  17.     wg.Add(1) 
  18.     b.SubmitBlock( 
  19.         func() { 
  20.             for _, notifier := range chunkCopy { 
  21.                 b.directSendMesg(notifier, mesg) 
  22.             } 
  23.             wg.Done() 
  24.         }, 
  25.     ) 
  26. wg.Wait() 

按線上的監(jiān)控表現(xiàn)來看,時延從200ms降到30ms。這里可以做一個更深入的優(yōu)化,對于少于5000的客戶端,可直接串行調(diào)用,反之可并發(fā)調(diào)用。

問題三:過多的定時器造成cpu開銷加大

行情推送里有大量的心跳檢測,及任務(wù)時間控速,這些都依賴于定時器。go在1.9之后把單個timerproc改成多個timerproc,減少了鎖競爭,但四叉堆數(shù)據(jù)結(jié)構(gòu)的時間復(fù)雜度依舊復(fù)雜,高精度引起的樹和鎖的操作也依然頻繁。

所以,這里改用時間輪解決上述的問題。數(shù)據(jù)結(jié)構(gòu)改用簡單的循環(huán)數(shù)組和map,時間的精度弱化到秒的級別,業(yè)務(wù)上對于時間差是可以接受的。

Golang時間輪的代碼已經(jīng)推到github[3]了,時間輪很多方法都兼容了golang time原生庫。有興趣的可以看下。

問題四:多協(xié)程讀寫chan會出現(xiàn)send closed panic的問題

解決的方法很簡單,就是不要直接使用channel,而是封裝一個觸發(fā)器,當(dāng)客戶端關(guān)閉時,不主動去close chan,而是關(guān)閉觸發(fā)器里的ctx,然后直接刪除topic跟觸發(fā)器的映射。

  1. // xiaorui.cc 
  2.  
  3. // 觸發(fā)器的結(jié)構(gòu) 
  4. type StreamNotifier struct { 
  5.     Guid  string 
  6.     Queue chan interface{} 
  7.  
  8.  
  9.     closed int32 
  10.     ctx    context.Context 
  11.     cancel context.CancelFunc 
  12.  
  13.  
  14. func (sc *StreamNotifier) IsClosed() bool { 
  15.     if sc.ctx.Err() == nil { 
  16.         return false 
  17.     } 
  18.     return true 
  19.  
  20. ... 

問題五:提高grpc的吞吐性能

grpc是基于http2協(xié)議來實現(xiàn)的,http2本身實現(xiàn)流的多路復(fù)用。通常來說,內(nèi)網(wǎng)的兩個節(jié)點使用單連接就可以跑滿網(wǎng)絡(luò)帶寬,無性能問題。但在golang里實現(xiàn)的grpc會有各種鎖競爭的問題。

如何優(yōu)化?多開grpc客戶端,規(guī)避鎖競爭的沖突概率。測試下來qps提升很明顯,從8w可以提到20w左右。

可參考以前寫過的grpc性能測試[4]。

問題六:減少協(xié)程數(shù)量

有朋友認(rèn)為等待事件的協(xié)程多了無所謂,只是占內(nèi)存,協(xié)程拿不到調(diào)度,不會對runtime性能產(chǎn)生消耗。這個說法是錯誤的。雖然拿不到調(diào)度,看起來只是占內(nèi)存,但是會對 GC 有很大的開銷。所以,不要開太多的空閑的協(xié)程,比如協(xié)程池開的很大。

在推送的架構(gòu)里,push-gateway到push-server不僅幾個連接就可以,且?guī)资畟€stream就可以。我們自己實現(xiàn)大量消息在十幾個stream里跑,然后調(diào)度通知。在golang grpc streaming的實現(xiàn)里,每個streaming請求都需要一個協(xié)程去等待事件。所以,共享stream通道也能減少協(xié)程的數(shù)量。

問題七:GC 問題

對于頻繁創(chuàng)建的結(jié)構(gòu)體采用sync.Pool進(jìn)行緩存。有些業(yè)務(wù)的緩存先前使用list鏈表來存儲,在不斷更新新數(shù)據(jù)時,會不斷的創(chuàng)建新對象,對 GC 造成影響,所以改用可復(fù)用的循環(huán)數(shù)組來實現(xiàn)熱緩存。

后記

有坑不怕,填上就可以了。

參考資料

[1]github: https://github.com/rfyiamcool/ccmap/blob/master/syncmap.go

[2]benchmark: https://github.com/rfyiamcool/go-benchmark/tree/master/batch_notify_channel

[3]github: https://github.com/rfyiamcool/go-timewheel

[4]測試: https://github.com/rfyiamcool/grpc_batch_test

 

責(zé)任編輯:武曉燕 來源: 碼農(nóng)桃花源
相關(guān)推薦

2022-08-16 09:23:54

分布式系統(tǒng)

2023-11-19 23:24:21

Golang開發(fā)

2010-07-06 09:39:20

SQL Server分

2019-06-19 15:40:06

分布式鎖RedisJava

2024-05-20 09:14:20

2019-10-10 09:16:34

Zookeeper架構(gòu)分布式

2023-05-12 08:23:03

分布式系統(tǒng)網(wǎng)絡(luò)

2023-05-29 14:07:00

Zuul網(wǎng)關(guān)系統(tǒng)

2017-09-01 05:35:58

分布式計算存儲

2022-12-08 08:13:11

分布式數(shù)據(jù)庫CAP

2022-06-08 07:36:03

LocustKubernete微服務(wù)

2018-07-19 14:53:23

秒殺websocket異步

2023-02-11 00:04:17

分布式系統(tǒng)安全

2017-10-27 08:40:44

分布式存儲剪枝系統(tǒng)

2024-05-23 10:19:57

2023-10-26 18:10:43

分布式并行技術(shù)系統(tǒng)

2024-01-10 08:02:03

分布式技術(shù)令牌,

2018-07-17 08:14:22

分布式分布式鎖方位

2024-03-01 09:53:34

2013-12-27 10:56:42

分布式對象存儲Sheepdog性能測試
點贊
收藏

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

国产区精品区| 精品国模一区二区三区| 成人精品小蝌蚪| 97超级碰碰碰久久久| 久久久久亚洲av成人无码电影| 朝桐光一区二区| 亚洲欧美偷拍卡通变态| 国产三区精品| 亚洲一线在线观看| 99国产精品| 日韩在线中文字| 日本国产在线视频| 国内精品伊人| 欧美性xxxxxxx| 综合久久国产| 青青国产在线| 国产精品99久久久久久似苏梦涵| 国产91成人在在线播放| 亚洲综合网在线| 国产欧美日韩精品一区二区免费 | 欧美国产激情视频| 国产日产一区二区三区| 91美女片黄在线| www.成人av| 97免费观看视频| 久久九九免费| 国内精品伊人久久| 九九热最新地址| 欧美r级电影| 亚洲欧美日韩网| 成人免费看片载| 91麻豆精品国产综合久久久 | 欧洲成人免费视频| 九九热国产在线| 99精品视频在线观看播放| 亚洲美女久久久| 久久久久久久人妻无码中文字幕爆| 日韩午夜视频在线| 91国产视频在线观看| 男人日女人视频网站| √天堂8在线网| 一区精品在线播放| 亚洲欧美综合一区| 国产原创av在线| 久久久蜜臀国产一区二区| 国产欧美日韩视频一区二区三区| 亚洲国产精品suv| 国产经典欧美精品| 91亚洲一区精品| 99久久久久成人国产免费| 久久精品免费观看| 国产精品揄拍500视频| 中文字幕 视频一区| 视频一区二区不卡| 日韩av黄色在线观看| 国产又大又粗又爽| 久久精品卡一| 国产精品r级在线| 波多野结衣网站| 日本亚洲免费观看| 国产日韩在线观看av| 一级做a爱片性色毛片| 精品一区精品二区高清| 亚洲最大的成人网| www.精品久久| 成人av午夜影院| 欧美一级爽aaaaa大片| 黄色av免费在线观看| 国产午夜精品一区二区| 先锋影音一区二区三区| 亚洲欧美视频一区二区| 国产精品不卡一区| 免费观看中文字幕| 欧美xxxx视频| 欧美体内谢she精2性欧美| 日本wwww视频| 国产成人免费精品| 欧美一区二区三区啪啪| 国产伦精品一区二区三区精品| 看全色黄大色大片免费久久久| 亚洲韩国青草视频| 精品无人区无码乱码毛片国产| 欧美日韩在线二区| 欧美另类极品videosbest最新版本 | wwwwxxxx日韩| 老司机亚洲精品一区二区| 精品1区2区在线观看| 91中文字幕永久在线| 婷婷色综合网| 91av国产在线| 国产乱人乱偷精品视频a人人澡| 国产成人综合网| 欧美激情国产日韩| 国产欧美久久久久久久久| 亚洲成av人在线观看| 丰满少妇在线观看| 日韩一级淫片| 国产一区二区三区在线视频| 欧美偷拍第一页| 久久激情婷婷| 99国产在线视频| 美女欧美视频在线观看免费| 亚洲精品中文在线观看| 久章草在线视频| 亚洲一区二区三区久久久| 9999精品成人免费毛片在线看| 国产视频网站在线| 综合久久久久久| 国产老熟妇精品观看| 欧美爱爱视频| 亚洲国产毛片完整版| 国产第一页浮力| 三级在线观看一区二区| 国产二区不卡| 日本三级在线视频| 欧美色另类天堂2015| 一区二区三区国产好的精华液| 精品一区免费| 97视频免费看| 国产丰满美女做爰| 国产精品麻豆网站| 亚洲熟妇av一区二区三区| 欧美激情精品| xxxxx91麻豆| 国产精品xxxxxx| 91视频免费看| 国产va亚洲va在线va| 亚洲精品tv| 色诱女教师一区二区三区| 丁香社区五月天| 97se亚洲国产综合自在线不卡| 中国女人做爰视频| 国产精品欧美一区二区三区不卡| 中文字幕在线精品| 中文字幕免费视频观看| 久久精品人人爽人人爽| 亚洲熟妇av一区二区三区漫画| 伊人久久亚洲| 欧美激情第三页| 亚洲精品综合久久| 一区二区免费在线播放| 91香蕉国产线在线观看| 午夜精品毛片| 亚洲综合在线做性| av在线免费观看网址| 91精品国产欧美一区二区| 天堂av免费在线| 麻豆91小视频| 中文字幕一区二区三区四区五区 | 亚洲在线一区二区| 蜜桃视频网站在线| 欧美精品18+| www.99re6| 韩国成人精品a∨在线观看| 亚洲人成77777| 综合久久av| 美日韩在线视频| 国产偷人妻精品一区二区在线| 18成人在线观看| 91丨porny丨九色| 国产专区一区| 美国av一区二区三区| 黄色亚洲网站| 中文字幕国产亚洲2019| 国产又粗又长视频| 亚洲精品伦理在线| 稀缺小u女呦精品呦| 99精品99| 日韩电影大全在线观看| 国产成人精品一区二区三区免费| yw.139尤物在线精品视频| 国产丝袜视频在线观看| 亚洲高清视频中文字幕| 在线免费观看麻豆| 精品一区二区三区不卡| 日韩国产小视频| 亚洲欧洲免费| 91久久国产精品91久久性色| 久久亚洲资源| 亚洲性线免费观看视频成熟| 91丨九色丨丰满| 亚洲国产你懂的| 中文字幕一区二区三区人妻电影| 日本在线不卡视频| 黄网站色视频免费观看 | 日韩三级电影网站| 精品一区二区三区在线观看视频 | 在线观看成人免费| 巨人精品**| 91精品国产自产在线观看永久| 天堂亚洲精品| 亚洲视频在线观看网站| 97国产精品久久久| 亚洲国产成人av网| 国产视频123区| 成人aaaa免费全部观看| 牛夜精品久久久久久久| 欧美激情性爽国产精品17p| 精品一区二区久久久久久久网站| 国产成人亚洲一区二区三区| 久久免费高清视频| 3d成人动漫在线| 亚洲福利视频网站| 国产麻豆91视频| 在线免费视频一区二区| 久久久久久蜜桃| 国产精品久久久久久久久快鸭| 中文字幕无码人妻少妇免费| 久久99国内精品| 欧美日韩一区二区在线免费观看| 亚洲色图88| 色涩成人影视在线播放| 卡通动漫精品一区二区三区| 91夜夜揉人人捏人人添红杏| 另类中文字幕国产精品| 久久久久久久网站| 成人欧美在线| 色综合伊人色综合网| 欧美孕妇孕交| 亚洲第一视频网| 国产wwwxxx| 337p亚洲精品色噜噜| 久久久久久无码午夜精品直播| 一区二区三区四区不卡在线| 国产大屁股喷水视频在线观看| 久久久久久久久久久久久女国产乱| 动漫av在线免费观看| 国产麻豆一精品一av一免费| 天天干天天综合| 日本成人在线一区| 乱子伦视频在线看| 午夜在线a亚洲v天堂网2018| 欧美高清中文字幕| 你懂的亚洲视频| 法国空姐在线观看免费| 欧美成人激情| 一区二区精品在线| 欧美日韩激情| 日本在线免费观看一区| 精品一区在线| 日本一区二区免费看| 你懂的视频欧美| 日本在线观看一区二区| 精品久久一区| 欧美一区二区三区四区夜夜大片 | 国产精品自拍电影| 欧美日韩三级一区二区| 美女黄页在线观看| 欧美日韩中文精品| 国产精品羞羞答答在线| 91精品啪在线观看国产60岁| 国产美女www爽爽爽视频| 3d动漫精品啪啪| jlzzjlzzjlzz亚洲人| 日韩精品一区二区三区三区免费 | 久久av高潮av| 亚洲国产专区校园欧美| 麻豆tv在线播放| 性欧美videos另类喷潮| 老头吃奶性行交视频| 美女一区二区三区| 91精产国品一二三产区别沈先生| 激情综合亚洲精品| 俄罗斯女人裸体性做爰| 成人av在线电影| xxx在线播放| 国产精品久久久久一区| 亚洲最大的黄色网址| 一区二区日韩av| 国产精品100| 欧美性大战xxxxx久久久| 一卡二卡在线观看| 欧美mv日韩mv国产网站app| 天天色天天操天天射| 亚洲色图50p| а√天堂官网中文在线| 欧美激情一区二区三区在线视频观看| www在线观看黄色| 国产精品海角社区在线观看| 午夜精品久久久久久毛片| 粉嫩av免费一区二区三区| 中文字幕伦av一区二区邻居| 中文字幕日韩精品久久| 夜夜嗨一区二区三区| 色综合色综合色综合色综合| 高清不卡在线观看| 在线观看福利片| 亚洲激情中文1区| 最近免费中文字幕大全免费版视频| 欧美美女一区二区在线观看| 少妇av在线播放| 色999日韩欧美国产| а√天堂中文在线资源8| 国产精品欧美激情| 成人黄色av网址| 亚洲亚洲精品三区日韩精品在线视频| 午夜国产精品视频免费体验区| 国产a级一级片| 国产在线精品一区二区夜色| 精品人妻互换一区二区三区| 依依成人精品视频| 久久久久久久久久一级| 精品少妇一区二区三区视频免付费| jizzjizz在线观看| 久久久日本电影| 57pao成人永久免费| 欧洲一区二区日韩在线视频观看免费 | 亚洲欧美三级伦理| 在线欧美三级| 国产免费一区二区三区香蕉精| 欧美色图婷婷| www.国产亚洲| 免费国产亚洲视频| 亚洲av片不卡无码久久| 一区二区久久久久久| 中文在线字幕av| 亚洲欧美日韩高清| av电影在线免费| 91久久精品一区二区别| 国产高清欧美| 91女神在线观看| 久久精品视频一区二区三区| 日本熟妇乱子伦xxxx| 日韩午夜小视频| 国产在线69| 国产噜噜噜噜噜久久久久久久久 | www插插插无码免费视频网站| 日本v片在线高清不卡在线观看| 欧美大片免费播放器| 亚洲一区二区av电影| 国产欧美第一页| 日韩中文字幕亚洲| 精品久久99| 亚洲日本精品国产第一区| 丝袜诱惑亚洲看片| 亚洲最大成人网站| 精品久久久久久久久久久久久久| 亚洲免费国产视频| 欧美黄色片在线观看| 日韩一区二区三区色 | 亚洲激情亚洲| 亚洲一区二区三区四区av| 伊人开心综合网| 国产99视频在线| 欧美极品美女电影一区| 日韩视频一区二区三区四区| 91视频 - 88av| www.欧美色图| 日韩黄色在线播放| 亚洲人精选亚洲人成在线| 奇米777日韩| 婷婷久久青草热一区二区| 麻豆高清免费国产一区| 蜜桃av.com| 日韩欧美一二三四区| 色呦呦呦在线观看| 国新精品乱码一区二区三区18| 一区三区视频| 亚洲第一页av| 欧美三级电影在线看| 老司机午夜在线视频| 亚洲自拍小视频| 一本久道久久综合狠狠爱| 国产精品高清无码在线观看| 欧美亚洲自拍偷拍| 激情视频在线观看| 岛国视频一区| 新67194成人永久网站| 国产又粗又硬视频| 91精品国产乱码| 成人免费图片免费观看| 欧美中文娱乐网| 国产中文字幕精品| 日本五十熟hd丰满| 亚洲免费视频观看| 日韩城人网站| 人妻夜夜添夜夜无码av| 国产亚洲综合色| 国产口爆吞精一区二区| 久久久久久久激情视频| 国产成人影院| 中文字幕一二三区| 欧美日韩在线视频观看| www.成人.com| 国产精品久久7| 全国精品久久少妇| 久久久久久国产精品视频| 精品视频在线导航| av在线精品| 1024精品视频| 亚洲免费在线视频| 亚洲人成色777777精品音频| 国产日韩在线看| 国产精品女主播一区二区三区| 久久精品日韩无码| 日韩av综合网| 国产一区二区视频在线看| 久久久久久久久久久久久国产精品| 亚洲欧美在线另类| 日韩二区三区|