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

彈幕系統(tǒng)更新的血與淚

云計算
隨著公司直播業(yè)務(wù)的變化,彈幕系統(tǒng)從最初的版本到后來優(yōu)化了三四個版本,這個過程大概持續(xù)了一年的時間,本文將從我司早期的彈幕系統(tǒng)開始給大家介紹整個更新過程的“血與淚 ”。

16年是直播浪潮興起的元年,許多互聯(lián)網(wǎng)公司的業(yè)務(wù)都開始涉足直播內(nèi)容模塊。我目前所在公司接手的第一份工作,就是直播業(yè)務(wù)中的彈幕系統(tǒng)優(yōu)化。隨著公司直播業(yè)務(wù)的變化,彈幕系統(tǒng)從最初的版本到后來優(yōu)化了三四個版本,這個過程大概持續(xù)了一年的時間,本文將從我司早期的彈幕系統(tǒng)開始給大家介紹整個更新過程的“血與淚 ”。

早期彈幕系統(tǒng)

一、基本狀況

1.由PHP + Gateway框架編寫

2.所有的Client ID存放在Redis里面

3.最初由三臺機器掛載在LVS系統(tǒng)后方提供服務(wù)

4.使用多進程的方式,開啟多個worker進程來處理消息傳遞內(nèi)容

二、存在的問題

1.內(nèi)存占用量巨大,單機(4核8G配置)承受500左右的Client就會達到內(nèi)存上限

2.每次發(fā)送消息的時候,每臺機器都需要從Redis里面拿取對應(yīng)房間的所有Client ID;并發(fā)高時,Redis的單進程處理效率和內(nèi)網(wǎng)帶寬就成為瓶頸 。

3.單機的并發(fā)處理能力被消息處理的worker進程數(shù)量限制。同時開啟過多的進程,也是對系統(tǒng)資源的格外浪費。

4.單房間超過2000人的時候,消息的延遲有可能會達到1分鐘左右,這是極其嚴重的問題。

三、臨時改造

由于需要解決的問題比較緊迫,所以快速做了一些邏輯上的改變和業(yè)務(wù)層面的取舍:

1.對Redis的實例進行了拆分,使用了雙機,單機4實例的方式,分散了Redis的壓力

2.對消息處理worker進程的邏輯做了一些修改,限制了單位時間內(nèi)進行廣播的消息數(shù)量,多余的消息會被丟棄 。

3.對于已經(jīng)完成了直播進入點播狀態(tài)的房間,額外啟用了另外一套彈幕系統(tǒng)來進行分流。

4.單個房間切成多個房間進行消息處理。

四、改造之后的效果

1.Redis壓力大幅度降低

2.單機IO性能壓力降低

3.同樣數(shù)量的機器,可以承載更多的直播房間個數(shù)

 

[[215183]]

 

但是,根本問題并沒有得到解決。在臨時解決壓力問題之后,我們需要花一些時間來重新對彈幕系統(tǒng)進行分析,按照分析后的需求,對新的彈幕系統(tǒng)進行重構(gòu)。

新的彈幕系統(tǒng)

一、新彈幕系統(tǒng)面臨的挑戰(zhàn)

1.單房間人數(shù)較高,依照我們公司直播情況,單房間5 – 10萬人同時在線是會出現(xiàn)的。

2.由于直播內(nèi)容等情況造成的某時間段用戶暴漲。

3.需要盡可能實時到達,延遲過高的話會大大降低互動的實時性。

4.每一條消息,都要遞送大量的長連接。

5.大量長連接的維護機制。

6.在運營的過程中,需要處理用戶黑名單、IP黑名單、敏感詞等需求。

二、新的彈幕系統(tǒng)需求

1.由于內(nèi)存的管理對于PHP來說算是一個短板,對于大并發(fā)且長時間穩(wěn)定不需要經(jīng)常更新維護的系統(tǒng)來說,并非最好的選擇,因此選一門合適的語言是必須的。

2.分布式支持,可以快速的橫向擴展,單房間人數(shù)可以支持到十萬級別。

3.可以方便快捷的對系統(tǒng)進行第三方消息的發(fā)送(例如禮物信息、系統(tǒng)通知等)。

4.盡量使用本地內(nèi)存管理來記錄房間內(nèi)客戶端連接,剩下大量的數(shù)據(jù)交互和查詢時間。

5.并發(fā)支持消息廣播,提高廣播效率。

三、新彈幕系統(tǒng)版本的改造方法

1.選擇當前正紅且對高并發(fā)支持良好的Golang作為開發(fā)語言。

2.使用開發(fā)語言進行客戶端連接的管理,且每臺機器只管理自己收到的連接請求。

3.使用并發(fā)的房間內(nèi)廣播邏輯,同時對多人進行廣播。

新彈幕系統(tǒng)改造的相關(guān)經(jīng)驗

下面先對一個模塊細節(jié)進行分析,然后進一步分析模塊上層的調(diào)度邏輯。

一、房間管理

  1. type RoomInfo struct { 
  2. RoomID string //房間ID 
  3. Lock *sync.Mutex //房間操作鎖 
  4. Rows []*RowList //房間多行Slice 
  5. Length uint64 //當前房間總節(jié)點數(shù) 
  6. LastChangeTime time.Time //最后一次更新時間 
  7. type RowList struct { 
  8. Nodes []*Node //節(jié)點列表 

由于每個房間都有自己的ID,客戶端建立連接之后,就會被放到一個大廳房間里面。接著,客戶端自己提交RoomID上來,連接會被重新連接到對應(yīng)的房間里面。 每個連接在建立之后,都會被包裝成一個Node,放到Rows里面。

  1. type Node struct { 
  2. RoomID string 
  3. ClientID int64 
  4. Conn *websocket.Conn 
  5. UpdateTime time.Time 
  6. LastSendTime time.Time //最后一次發(fā)送消息時間 
  7. IsAlive bool 
  8. DisabledRead bool//是否已經(jīng)被關(guān)閉了發(fā)言權(quán)限 

每一個Node中,都有一個IsAlive來表示連接是否成功。如果連接斷開,或者因為其他原因強制停止服務(wù)的話,會修改此標記狀態(tài)。然后由定時的處理機制將此連接關(guān)閉并從內(nèi)存中清除。 Rows的本質(zhì)就是一組事先設(shè)定了長度的Node Slice。

發(fā)送消息的時候,每一組slice使用一個協(xié)程來順序發(fā)送。同一房間內(nèi)的連接,就可以依照slice分組進行并發(fā)發(fā)送。 發(fā)送的時候,會使用鎖將整個房間鎖住,以防止并發(fā)情況下同一連接混入兩條信息。

二、消息管理

  1. var messageChannel map[string]chan nodeMessage 
  2. func init() { 
  3. messageChannel = make(map[string]chan nodeMessage) 
  4. func sendMessageToChannel(roomId string, nm nodeMessage) error { 
  5. //如果房間不存在,創(chuàng)建一個房間 
  6. if c, ok := messageChannel[roomId]; ok { 
  7. else { 
  8. //創(chuàng)建房間通道 
  9. messageChannel[roomId] = make(chan nodeMessage, 1024) 
  10. messageChannel[roomId] 
  11. //創(chuàng)建房間實例 
  12. roomObj := &RoomInfo{} 
  13. roomObj.RoomID = roomId 
  14. roomObj.Rows = make([]*RowList, 0, 4) 
  15. roomObj.Lock = &sync.Mutex{} 
  16. //創(chuàng)建新的協(xié)程來監(jiān)控房間 
  17. go daemonReciver(messageChannel[roomId], roomObj) 
  18. go timerForClean(messageChannel[roomId]) 
  19. //如果是大廳的話,啟動大廳清理協(xié)程 
  20. if roomId == "" { 
  21. go CleanHall(roomObj) 
  22. return nil 

以上是關(guān)于彈幕信息傳遞的一部分代碼。 首先,每一個房間,都有自己的消息通道,所有的這些通道根據(jù)RoomID為key,記錄在一個叫做messageChannel的map里面。 每次收到消息的時候,都直接把消息丟到channel里面,就可以了。(后面由守護協(xié)程來處理)如果沒有房間通道的話,就建立房間的通道channel,并啟動每個房間的一系列協(xié)程。

三、服務(wù)器管理

這里的方案比較簡單,其實就是建立一個上一層的聊天室即一個房間,所有的服務(wù)器都會主動連接到這里,每一個服務(wù)器收到的信息,就會在這個房間里面廣播到別的機器去。

四、守護協(xié)程們管理

守護協(xié)程處理很多瑣碎的事情,保證房間內(nèi)信息的正常分發(fā)以及房間連接的正常管理。各個守護協(xié)程的功能如下:

1.消息發(fā)送協(xié)程:每個房間配備一個,從channel里面獲取到要發(fā)送到本房間的消息,然后在并發(fā)調(diào)用各個RowList的發(fā)送消息機制。

2.房間整理協(xié)程:因為會有連接斷開、房間更換等修改Node狀態(tài)的行為,所以定期會有房間整理協(xié)程來進行節(jié)點整理,刪除當前房間無關(guān)的節(jié)點等以提高消息的發(fā)送效率。

[[215184]]

五、測試相關(guān)

運行環(huán)境:云主機8核16G實例

操作系統(tǒng):Centos7(未進行系統(tǒng)優(yōu)化或參數(shù)調(diào)整)

測試內(nèi)容:單機建立15000 websocket連接,并且發(fā)送消息,進入指定房間(所有連接進入同一房間)。一個客戶端進入房間,發(fā)送一條消息,經(jīng)過敏感詞處理、IP和用戶黑名單處理,然后被廣播到所有節(jié)點。

測試結(jié)果:

CPU占用:保持在5%以下

內(nèi)存占用:2GB(包括操作系統(tǒng)本身開銷)

網(wǎng)絡(luò)占用:峰值10Mb/s左右

發(fā)送效率:15000節(jié)點廣播,100ms – 110ms左右。

根據(jù)測試結(jié)果計算:

完全可以在8核16G的機器上,實現(xiàn)無壓力運行50K并發(fā),峰值接近60 – 70K的處理能力。

六、更多分享

我目前正在嘗試把完成這套彈幕系統(tǒng)的基本功能開源出來。已經(jīng)提取出來了一部分,當前的地址為:https://github.com/logan-go/roomManager,感興趣的讀者可以通過鏈接查看。

小結(jié)

彈幕系統(tǒng)給視頻直播/點播增加了更多內(nèi)容的互動娛樂性質(zhì),從最初的A站B站發(fā)展到現(xiàn)在各主流視頻網(wǎng)站APP。如何健康高效的管理彈幕系統(tǒng),也是當下視頻行業(yè)需要重視的一門技術(shù)活。

責任編輯:武曉燕 來源: ucloud博客
相關(guān)推薦

2017-12-22 10:01:42

彈幕直播內(nèi)存

2014-08-01 14:32:29

創(chuàng)業(yè)90后創(chuàng)業(yè)

2018-04-11 15:42:04

開源項目姿勢

2012-12-24 09:18:22

iOSUnity3D

2017-05-11 22:43:53

2025-06-16 04:00:00

Spring彈幕技術(shù)

2025-06-16 01:00:00

彈幕系統(tǒng)架構(gòu)

2015-07-16 12:37:28

彈幕

2011-01-14 16:51:44

Linux內(nèi)核

2019-01-02 16:47:46

Golang彈幕

2019-01-02 16:38:37

Golang彈幕

2019-01-02 16:50:30

Golang彈幕

2019-11-20 18:47:26

物聯(lián)網(wǎng)OTA軟件

2025-08-15 07:36:48

彈幕系統(tǒng)Spring

2010-04-28 15:38:54

2010-12-23 14:17:14

Web 2.0

2018-05-08 09:00:00

系統(tǒng)更新

2023-01-04 09:29:03

線程業(yè)務(wù)代碼

2021-06-22 18:28:58

程序員技能開發(fā)者
點贊
收藏

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

日本一区二区成人| 欧美视频导航| 欧美电影一区二区三区| 国产免费xxx| 亚洲精品一区二区三区新线路| 日韩午夜在线电影| 一色桃子一区二区| 在线观看网站黄| 免费高潮视频95在线观看网站| 久久久久国产精品人| 成人黄色免费看| 日韩欧美亚洲视频| 99成人在线视频| 日韩国产精品视频| 天堂av8在线| 在线最新版中文在线| 中文字幕一区二| 久久久久久一区| 国产乱色精品成人免费视频| 国产一区二区三区成人欧美日韩在线观看| 夜夜嗨av一区二区三区四区| 日本一区二区在线观看视频| 北岛玲heyzo一区二区| 亚洲欧美成人一区二区三区| 欧美日韩国产三区| 国产成人手机在线| 国模一区二区三区白浆| 78色国产精品| 美女的奶胸大爽爽大片| 欧美少妇xxxx| 亚洲国产免费av| 天天操精品视频| 欧美日韩123区| 亚洲成精国产精品女| 日本不卡一区二区三区四区| 精品三级久久久久久久电影聊斋| 美女爽到高潮91| 欧美中文字幕视频| 国产精品99精品| 中文乱码免费一区二区三区下载| 伊人伊成久久人综合网小说 | 91九色成人| 91久久奴性调教| 九九九九免费视频| 啊啊啊久久久| 图片区小说区区亚洲影院| 9191国产视频| 欧洲在线视频| 亚洲综合偷拍欧美一区色| 亚洲三区四区| 素人av在线| 国产精品传媒入口麻豆| 欧美亚洲精品日韩| 精品视频三区| 国产女同性恋一区二区| 日韩精品久久一区二区三区| 国产在线自天天| 国产香蕉久久精品综合网| 久久久久久草| 国产永久免费高清在线观看视频| 久久品道一品道久久精品| 久久久精品动漫| 天天干,夜夜爽| av欧美精品.com| 久久久久久99| 国产一区电影| 亚洲欧美中日韩| eeuss中文| 日韩av官网| 亚洲va欧美va人人爽| 91九色丨porny丨国产jk| 韩国成人二区| 欧美特级www| 在线看的黄色网址| 国产精品1区| 亚洲高清av在线| 欧美做受喷浆在线观看| 精品国产乱码| 中文字幕成人精品久久不卡| 一本一本久久a久久| 欧美1区免费| 91精品国产91久久久久久久久 | 久久精品人人做人人爽电影蜜月| 青青青国产精品一区二区| 小泽玛利亚一区二区三区视频| 久久精品久久久精品美女| 亚洲自拍偷拍一区| 天天综合在线视频| 中文字幕在线播放不卡一区| 亚洲精品天堂成人片av在线播放| 丁香花高清在线观看完整版| 色欧美日韩亚洲| 在线a免费观看| 亚洲va久久久噜噜噜久久| 中文字幕av一区中文字幕天堂| 国产a免费视频| 久久国产日韩| 亚洲xxx视频| 你懂的视频在线免费| 中文字幕在线观看不卡| 欧美久久在线观看| 国产成人久久精品麻豆二区| 欧美精品一区二区三| 四虎国产成人精品免费一女五男| 欧美特黄a级高清免费大片a级| 51久久精品夜色国产麻豆| 91久久精品无码一区二区| 99精品久久只有精品| 精品一区二区成人免费视频 | 91免费国产网站| 亚洲av毛片成人精品| 亚洲欧洲日韩综合一区二区| 777久久久精品一区二区三区| 91精品福利观看| 亚洲欧美精品在线| 国产一级av毛片| 久久99久久久久久久久久久| 久久这里精品国产99丫e6| 色呦呦在线视频| 欧美日韩国产a| 在线免费观看麻豆| 日韩一区二区久久| 91九色蝌蚪成人| av基地在线| 日韩欧美亚洲国产一区| 性欧美18—19sex性高清| 97在线精品| 2019中文字幕免费视频| www男人的天堂| 成人欧美一区二区三区白人 | 96sao精品免费视频观看| 国产婷婷97碰碰久久人人蜜臀| 在线免费观看亚洲视频| 蜜桃久久av一区| 日本视频一区在线观看| 亚洲美女尤物影院| 亚洲精品久久久一区二区三区| 永久看片925tv| 国产在线播放一区二区三区| 亚洲一区免费看| 91av一区| 少妇精69xxtheporn| 免费精品一区二区| 国产日韩三级在线| 久久久久狠狠高潮亚洲精品| 欧美激情久久久久久久久久久| 欧美精品aaa| 亚洲精品网站在线| 亚洲一区二区三区四区在线观看| 在线观看网站黄| 91超碰成人| 91超碰rencao97精品| av香蕉成人| 日韩欧美卡一卡二| 一区二区三区免费高清视频| 成人一级视频在线观看| 久久99久久久久久| 色天天色综合| 日韩美女视频在线观看| 福利片在线看| 717成人午夜免费福利电影| www欧美com| 成人性生交大片免费| 无码熟妇人妻av在线电影| 成人影院中文字幕| 欧美一区视频在线| yw193.com尤物在线| 欧美日韩的一区二区| 美女三级黄色片| 丁香桃色午夜亚洲一区二区三区| 人妻少妇精品久久| 久久av超碰| 成人免费淫片视频软件| 欧美韩日亚洲| 亚洲欧洲高清在线| 怡红院男人天堂| 亚洲精品福利视频网站| 国产xxxx视频| 日韩精品一区第一页| 婷婷视频在线播放| 国产精东传媒成人av电影| 茄子视频成人在线| 米奇777四色精品人人爽| 欧美videos大乳护士334| 800av免费在线观看| 国产精品婷婷午夜在线观看| 欧美性猛交xx| 性欧美长视频| 中国黄色录像片| 久久亚洲道色| 国产欧美婷婷中文| 国内精彩免费自拍视频在线观看网址| 在线观看国产精品91| 精品人妻一区二区三区三区四区 | 国产又粗又黄又爽| 五月婷婷综合激情| av资源在线免费观看| 不卡一二三区首页| 在线观看国产福利| 小嫩嫩精品导航| 特级黄色录像片| 国产精品免费99久久久| 99re在线| 欧美男男gaygay1069| 91av国产在线| 在线播放免费av| 一区二区国产精品视频| 黄色小视频免费观看| 精品污污网站免费看| 天天操天天干视频| 一区二区三区中文字幕精品精品| 亚洲永久无码7777kkk| 国产麻豆精品theporn| 久久精品免费网站| av成人天堂| 成人免费看片'免费看| 色999国产精品| 欧美黑人xxxxx| 大奶在线精品| 亚洲www视频| 欧美视频精品| 国产精品美女久久| 肉色欧美久久久久久久免费看| 久久99国产综合精品女同| 香蕉视频国产在线观看| 亚洲欧美成人精品| 亚洲aⅴ在线观看| 欧美精品一区二区三区高清aⅴ | 久久综合久久鬼色| 成年女人免费视频| 国产jizzjizz一区二区| 捷克做爰xxxⅹ性视频| 日本一区中文字幕| 91av在线免费播放| 久久国产欧美| 日日摸天天爽天天爽视频| 亚洲一卡久久| 欧美老熟妇喷水| 亚洲国产午夜| 欧美成人高潮一二区在线看| 亚洲特色特黄| 91.com在线| 影音先锋一区| 精品少妇一区二区三区在线| 在线看片日韩| 成人性生活视频免费看| 夜夜爽av福利精品导航| 天天夜碰日日摸日日澡性色av| 亚洲国产99| 啊啊啊一区二区| 久久精品三级| 日本 片 成人 在线| 久久99精品久久久久| 亚洲精品www.| 国产精品一区二区x88av| 潘金莲一级淫片aaaaa| 大白屁股一区二区视频| 欧美极品jizzhd欧美仙踪林| 成人动漫一区二区在线| 国产成人精品无码片区在线| 99国产麻豆精品| 亚洲一区二区三区蜜桃| 日本一区二区久久| 爱爱视频免费在线观看| 亚洲一二三四久久| 青青草成人av| 欧美日韩中文字幕一区| 国产精品高潮呻吟av| 日韩女优电影在线观看| 天天操天天射天天| 国产亚洲aⅴaaaaaa毛片| 在线激情免费视频| 欧美成人免费一级人片100| av在线网页| 国产精品av电影| 国产精品视频一区二区三区| 国产精品一区二区免费| 国产成人精品免费视| 亚洲自拍的二区三区| 欧美久色视频| 日韩精品无码一区二区三区免费| 麻豆成人在线观看| 麻豆短视频在线观看| 国产午夜精品一区二区三区四区| 91免费在线看片| 亚洲自拍偷拍图区| 亚洲 国产 日韩 欧美| 欧美一区二区久久| 男人天堂综合| 免费av一区二区| 亚洲最大成人| 91精品黄色| 青草国产精品| 免费拍拍拍网站| 免费看欧美美女黄的网站| 少妇极品熟妇人妻无码| 国产免费成人在线视频| 久久午夜无码鲁丝片| 欧美调教femdomvk| 免费观看黄色av| 日韩中文第一页| 在线天堂资源www在线污| 999热视频在线观看| 国产一区二区欧美| 国产原创中文在线观看 | a篇片在线观看网站| 欧亚精品中文字幕| 日本免费一区二区视频| 天天久久人人| 性欧美xxxx大乳国产app| 亚洲av无码成人精品区| 国产精品人成在线观看免费| 久久狠狠高潮亚洲精品| 91麻豆精品国产91久久久更新时间 | 免费精品视频一区| 欧美视频二区| 深夜福利网站在线观看| 国产精品理论在线观看| 久久精品无码av| 亚洲国产成人精品电影| gogogogo高清视频在线| 国产免费一区视频观看免费 | 色偷偷av一区二区三区乱| 国产精品迅雷| 激情小说综合区| 好看的日韩av电影| 黑人巨大猛交丰满少妇| 国产精品免费视频一区| 99久久久久久久久| 日韩电影免费在线观看中文字幕| 欧美性video| 1卡2卡3卡精品视频| 99久久.com| 99热一区二区| 国产精品美女久久久久高潮| 日批视频免费观看| 一区二区欧美日韩视频| 久久久成人av毛片免费观看| 久久久久久草| 性色av一区二区怡红| 亚洲专区区免费| 欧美午夜精品久久久久久人妖| 污污网站在线免费观看| 91精品国产九九九久久久亚洲| 99久久香蕉| 国产v片免费观看| 不卡av电影在线播放| 影音先锋亚洲天堂| 国产视频久久网| 伊人久久精品一区二区三区| 欧美精品在线一区| 视频一区免费在线观看| 神马久久久久久久久久久| 欧美四级电影在线观看| 幼a在线观看| 91久久精品国产91性色| 综合一区在线| 欧美日韩人妻精品一区在线| 偷拍一区二区三区四区| 毛片在线免费| 国产精品美女久久久久av超清| 91亚洲成人| japan高清日本乱xxxxx| 亚洲va在线va天堂| 国产露出视频在线观看| 国产精品一区二区三| 99久久99热这里只有精品| 少妇性l交大片7724com| 亚洲444eee在线观看| 你懂的视频在线免费| 国产日韩av在线播放| 女人天堂亚洲aⅴ在线观看| 人妻av一区二区| 欧洲一区二区三区免费视频| 黄av在线播放| 激情小说综合网| 美女视频第一区二区三区免费观看网站| 欧美性x x x| 亚洲精品理论电影| av成人在线播放| 日韩精品一区二区在线视频 | 国内精品伊人久久久久av一坑| 免费一级黄色大片| 亚洲欧美日韩国产中文| 成人噜噜噜噜| www.浪潮av.com| 亚洲色图.com| 涩涩视频在线观看免费| 成人高h视频在线| 亚洲精品裸体| 91精品少妇一区二区三区蜜桃臀| 亚洲激情视频网站| 日本成人在线网站| 日韩欧美一区二| 亚洲乱码日产精品bd| 免费毛片在线| av资源一区二区| 美女视频网站黄色亚洲| www.天天色| 久久九九免费视频|