精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

91免费黄视频| 欧美大片网站在线观看 | 男人的天堂在线免费视频| 丝袜美腿高跟呻吟高潮一区| 日韩亚洲欧美成人| 天堂www中文在线资源| 日韩新的三级电影| 亚洲综合清纯丝袜自拍| 五月天色一区| 成人午夜精品福利免费| 日韩高清不卡一区| 欧美激情xxxx| 又色又爽的视频| 风间由美中文字幕在线看视频国产欧美 | 国产午夜精品麻豆| 17c国产在线| 国模冰冰炮一区二区| 亚洲天堂成人网| 欧美精品欧美精品系列c| 国产乱淫a∨片免费观看| 欧美专区一区二区三区| 久久99国产精品久久久久久久久| 国产熟妇久久777777| 一区二区三区亚洲变态调教大结局 | 国产香蕉久久| 午夜精品一区二区三区三上悠亚 | 国产全是老熟女太爽了| 91久久精品无嫩草影院| 欧美日韩色综合| 亚洲视频一区在线| 91美女片黄在线观| 波多野结衣一区二区三区四区| 亚洲性感美女99在线| 日韩在线高清视频| 91精品久久久久久久久久久久| 粉嫩久久久久久久极品| 91精品国产综合久久精品性色| 91黄色小网站| 极品在线视频| 精品国产乱码久久久久久婷婷 | 一区二区久久| 欧美肥婆姓交大片| 日本一二三区在线观看| 日韩综合一区| 亚洲欧美激情在线视频| 一本加勒比波多野结衣| 风间由美中文字幕在线看视频国产欧美| 欧美乱妇23p| 911福利视频| 少妇精品视频在线观看| 欧美日韩成人综合天天影院 | 这里只有精品在线观看| 日本高清www| 免费精品国产| 国产亚洲精品一区二555| 午夜理伦三级做爰电影| 嫩草影视亚洲| 在线观看精品自拍私拍| 九九九视频在线观看| 欧美精品系列| 日韩一区二区欧美| 农村老熟妇乱子伦视频| 亚洲精品成人影院| 精品无码三级在线观看视频| 日韩av手机在线观看| 青青青国产在线 | 亚洲黄色尤物视频| 97中文字幕在线| 不卡av免费观看| 亚洲一区在线播放| 欧美激情 国产精品| 国产夫妻在线播放| 色久综合一二码| 天天色综合社区| 国产电影一区二区| 精品999在线播放| 亚洲欧美在线不卡| 成人黄色av| 久久久国产视频| 伊人国产在线观看| 天使萌一区二区三区免费观看| 国产精品久久久久免费a∨| 国产熟女一区二区三区五月婷| 国产精品一区二区黑丝| 久久99精品久久久水蜜桃| 美国一级片在线免费观看视频 | 久久99久久精品| 成人三级视频在线观看一区二区| 亚洲av成人精品一区二区三区在线播放| 国产偷v国产偷v亚洲高清| 亚洲欧洲三级| 91九色porn在线资源| 欧洲中文字幕精品| 深夜视频在线观看| 欧美亚洲高清| 欧美激情一级欧美精品| 亚洲天堂五月天| 高潮精品一区videoshd| 秋霞在线观看一区二区三区| 黄色网页在线免费看| 欧美日韩性视频| 色91精品久久久久久久久| 精品淫伦v久久水蜜桃| 永久免费精品影视网站| 日本少妇做爰全过程毛片| 免费在线观看一区二区三区| 国产精品免费一区二区三区在线观看| 免费黄色在线视频网站| 亚洲一二三区视频在线观看| 美女网站免费观看视频| 精品国产午夜肉伦伦影院| 在线中文字幕日韩| 亚洲影院在线播放| 国产乱人伦偷精品视频不卡| 青青成人在线| 色网在线免费观看| 精品国产自在久精品国产| 黄色国产在线播放| 久久精品欧洲| 国产一区免费在线| 91精品国产91久久久久久青草| 日本道色综合久久| 西西大胆午夜视频| 欧美三级在线| 成人a在线视频| 国产女人在线视频| 欧美日韩国产一区中文午夜| 三大队在线观看| 午夜影院欧美| 国产欧美日韩精品专区| 户外极限露出调教在线视频| 五月综合激情婷婷六月色窝| 香蕉久久久久久av成人| 欧美国产91| 91青青草免费观看| 成人短视频在线观看| 欧美卡1卡2卡| 日本裸体美女视频| 韩国三级中文字幕hd久久精品| 视频在线观看成人| 日韩一区二区三区在线免费观看 | 久久久7777| av免费不卡国产观看| 精品国一区二区三区| 久久久久久久久久91| 国产成人精品aa毛片| 伊人再见免费在线观看高清版| 四虎在线精品| 久热在线中文字幕色999舞| 又骚又黄的视频| 亚洲欧洲韩国日本视频| www.超碰97.com| 91精品一区国产高清在线gif | 人妻91麻豆一区二区三区| 亚洲综合色成人| 91视频在线免费| 亚洲一区成人| 日本在线观看一区| 色综合天天色| 久久五月情影视| 草草视频在线播放| 婷婷综合在线观看| 国产美女免费无遮挡| 日本在线不卡视频| 一区二区在线中文字幕电影视频| 国产精品一区免费在线| 欧美人成在线视频| 天堂av电影在线观看| 色视频一区二区| 亚洲精品自拍视频在线观看| 国产精品亚洲а∨天堂免在线| av一区二区三区免费观看| 女仆av观看一区| 国产极品jizzhd欧美| 女女色综合影院| 精品国产污网站| 手机看片久久久| 国产精品国产三级国产普通话蜜臀 | 久久av红桃一区二区小说| 亚洲精品无amm毛片| 欧美视频在线视频| xxxxx99| 成人高清av在线| 色多多视频在线播放| 欧美在线影院| 欧美三日本三级少妇三99| 青青国产精品| 欧美性视频在线| 浪潮av一区| 日韩精品在线观| 国产一区二区网站| 欧美视频在线观看免费网址| 人人艹在线视频| proumb性欧美在线观看| 天堂网在线免费观看| 影音先锋一区| 亚洲一区不卡在线| 牛牛视频精品一区二区不卡| 成人网址在线观看| 亚洲天堂av在线| 精品国产依人香蕉在线精品| 日本一区视频| 欧美一级免费观看| 日韩不卡高清视频| 亚洲午夜一区二区三区| 美女av免费看| 91丨porny丨户外露出| 在线视频日韩欧美| 久久精品人人| 欧美午夜小视频| 亚洲精品网址| 亚洲精品国产精品国自产观看 | 亚洲精品国产拍免费91在线| 97国产成人无码精品久久久| 欧美性色xo影院| 国产亚洲欧美精品久久久久久| 欧美国产精品v| 变态另类丨国产精品| 国产在线播精品第三| 亚洲性生活网站| 亚洲一区视频| 男人日女人视频网站| 国产精品九九| 免费在线精品视频| 国产精品传媒精东影业在线 | 国模私拍在线观看| 国产真实乱子伦精品视频| 麻豆三级在线观看| 老司机精品视频网站| 欧美深夜福利视频| 国内激情久久| 日韩黄色片在线| 亚洲国产日韩欧美在线| 中文字幕中文字幕99| 日韩国产一区| 亚洲乱码一区二区三区三上悠亚| 国产午夜一区| 欧美日本亚洲| 欧美精品系列| 亚洲图片在线观看| 久久麻豆精品| 一区二区三区我不卡| 日韩欧美精品一区| 亚洲日本一区二区三区在线不卡| 欧美日韩一区二区综合| 亚欧洲精品在线视频免费观看| 国产亚洲一区| 亚州欧美一区三区三区在线| 成人在线一区| 一本一道久久a久久精品综合| 色婷婷色综合| 国产成年人在线观看| 婷婷另类小说| 成人国产一区二区三区| 黄色工厂这里只有精品| 男女视频网站在线观看| 一区二区三区国产在线| 国产精品丝袜久久久久久消防器材| 国产精品普通话对白| 亚洲精品中文字幕无码蜜桃| 热久久国产精品| 天天综合成人网| 成人毛片老司机大片| 亚洲欧美在线不卡| 国产日韩在线不卡| 91日韩中文字幕| 亚洲mv在线观看| 日韩人妻精品中文字幕| 欧美三级电影网站| 国产xxxx孕妇| 日韩电影免费观看在线观看| 免费在线性爱视频| 日韩视频亚洲视频| 91超碰在线播放| 国产精品福利观看| 日本免费一区二区三区视频| 国内精品视频在线播放| 精品国产一区二区三区噜噜噜 | 日韩三级视频在线看| 天堂网在线中文| 一道本无吗dⅴd在线播放一区| 精品自拍一区| 91精品国产91久久| 青青国产精品| 精品视频在线观看| 欧美激情黄色片| 欧美久久在线观看| 老司机精品视频一区二区三区| 中文字幕第10页| 久久精品人人做| 欧美日韩在线观看免费| 色婷婷亚洲精品| www.黄色国产| 一区二区三区黄色| 美女尤物在线视频| 国产精品免费网站| 国产精品天天看天天狠| 亚洲aⅴ天堂av在线电影软件| 国内成人在线| 日韩高清第一页| 久久久欧美精品sm网站| 青娱乐国产在线| 欧美视频在线一区| 色视频在线观看| 色综合久综合久久综合久鬼88| 国产精品亲子伦av一区二区三区 | 成人直播大秀| 日韩av三级在线| 国产精品一区二区你懂的| 天天操天天舔天天射| 精品国产91久久久| 国产成人精品无码高潮| 中文字幕亚洲精品| 一区二区三区电影大全| 国产精品久久波多野结衣| 91视频一区| 亚洲免费av一区二区三区| av影院午夜一区| 青草草在线视频| 9191成人精品久久| av在线第一页| 日本精品视频在线观看| 麻豆精品av| av在线com| 国产99久久久久久免费看农村| 三级黄色录像视频| 欧美三级日韩三级| 69久久久久| 国产精品久久久久久久午夜| 亚洲成aⅴ人片久久青草影院| 国产免费一区二区视频| 国产经典欧美精品| 欧美一区二区三区爽爽爽| 欧美日韩精品久久久| 成人好色电影| 国产精品自产拍在线观看| 成人动漫免费在线观看| 超碰在线公开97| 国产精品久久影院| 一级黄色片免费| 免费h精品视频在线播放| av小片在线| 日韩美女视频中文字幕| 激情亚洲另类图片区小说区| 国产精品视频一二三四区| 激情av综合网| 国产日韩欧美在线观看视频| 欧美精选一区二区| 日本在线免费中文字幕| 国产在线观看不卡| 91精品高清| 少妇献身老头系列| 五月综合激情网| 男女污污视频在线观看| 国产精品精品视频一区二区三区| 精品在线观看入口| 亚洲黄色小视频在线观看| 国产精品美女久久福利网站| 97精品人妻一区二区三区香蕉| 久久电影一区二区| 都市激情久久| 无码无遮挡又大又爽又黄的视频| 久久久蜜臀国产一区二区| 伊人亚洲综合网| 另类专区欧美制服同性| 国内自拍欧美| 日韩手机在线观看视频| 1024成人网色www| 亚洲精品97久久中文字幕无码| 久久久噜久噜久久综合| 久操成人av| 国产无遮挡猛进猛出免费软件 | 亚洲国产黄色片| 欧美性suv| 警花观音坐莲激情销魂小说| 风间由美一区二区三区在线观看| 国产精品视频免费播放| 中文字幕日韩精品有码视频| 国产在线不卡一区二区三区| 欧美深夜福利视频| 中文字幕乱码久久午夜不卡| 精品久久久久中文慕人妻| 欧美中文字幕精品| 久久久国产精品| 国产呦小j女精品视频| 欧美精品 日韩| 依依综合在线| 蜜臀av.com| 国产三区在线成人av| 草草视频在线播放| 国产精品爽黄69| 99在线观看免费视频精品观看| 久久久久久久久福利| 精品久久久久久久一区二区蜜臀| 二吊插入一穴一区二区| 在线观看污视频| 日本一区二区三级电影在线观看| 亚洲成人精品女人久久久| 国产精品久久不能| 一区在线免费|