直播系統(tǒng)保持流暢簡析

直播系統(tǒng)流暢保證設(shè)計(jì)要點(diǎn)淺析

視頻播放不流暢,一般有兩個(gè)原因:
視頻播放不均勻正蛙。
比如,視頻幀原本是40ms一幀营曼,如果我們播放的時(shí)候乒验,一會20秒一幀進(jìn)行播放,一會兒60秒一幀進(jìn)行播放溶推,那么最后結(jié)果必定是會出現(xiàn)卡頓徊件。當(dāng)然奸攻,如果根據(jù)視頻時(shí)間戳蒜危,視頻幀間隔本來是20-60幀,我們強(qiáng)行按照40-40播放睹耐,也會進(jìn)行卡頓辐赞。也就是說,視頻播放時(shí)硝训,不遵循時(shí)間戳响委,將會導(dǎo)致卡頓發(fā)生。
視頻有丟幀窖梁。
視頻出現(xiàn)丟幀后赘风,會導(dǎo)致視頻不流暢。如果連續(xù)的丟幀太多纵刘,會導(dǎo)致出現(xiàn)明顯卡頓邀窃。如果參考幀丟失,則會影響到之后若干個(gè)幀假哎。

視頻出現(xiàn)馬賽克瞬捕,一般有兩個(gè)原因:
視頻ES不完整,也就是說舵抹,出現(xiàn)了數(shù)據(jù)丟包肪虎。
解碼器解碼非參考幀時(shí),參考了錯(cuò)誤的參考幀惧蛹。例如一個(gè)非參考幀之前的那個(gè)參考幀丟失扇救,那么會導(dǎo)致本幀會參考上上個(gè)參考幀,從而可能出現(xiàn)馬賽克香嗓。

事實(shí)上迅腔,在web網(wǎng)絡(luò)中,網(wǎng)絡(luò)情況非常復(fù)雜陶缺。同時(shí)保證視頻的實(shí)時(shí)性和流暢性钾挟,是很難的。但是饱岸,犧牲實(shí)時(shí)性來保證流暢掺出,這個(gè)是可以做到的徽千。下面,將從3個(gè)方面來研究怎么來讓視頻的播放體驗(yàn)更好汤锨。(下面的優(yōu)化痘绎,暫不考慮動態(tài)切換碼率藤违。)

視頻編碼發(fā)送端的優(yōu)化。
編碼發(fā)送端,首先必須保證時(shí)間戳的準(zhǔn)確性序愚,輸入給編碼器視頻幀的時(shí)候,準(zhǔn)確告訴其時(shí)間戳蛇耀。時(shí)間戳精確度可以達(dá)不到27MHz框喳,這個(gè)沒關(guān)系,但準(zhǔn)確性要保證锨并。當(dāng)然露该,精度需要至少達(dá)到毫秒級。
編碼器發(fā)送數(shù)據(jù)的目標(biāo)第煮,是保證所有數(shù)據(jù)都完整的發(fā)送到服務(wù)器端解幼。但網(wǎng)絡(luò)情況的復(fù)雜性,可能導(dǎo)致一些時(shí)候偶爾無法做到這一點(diǎn)包警。我們要做到的是撵摆,就是讓偶然的網(wǎng)絡(luò)故障不影響網(wǎng)絡(luò)數(shù)據(jù)的完整性。因此害晦,我們需要在發(fā)送端進(jìn)行數(shù)據(jù)緩存特铝。需要建立一個(gè)發(fā)送緩沖區(qū),編碼后的數(shù)據(jù)篱瞎,交給發(fā)送緩沖區(qū)苟呐,然后由發(fā)送模塊全力將發(fā)送緩沖區(qū)內(nèi)容發(fā)送到服務(wù)器。
如果網(wǎng)絡(luò)出現(xiàn)意外的時(shí)間較長俐筋,或者網(wǎng)絡(luò)中斷牵素。如果數(shù)據(jù)不斷被提交給發(fā)送緩沖區(qū),而發(fā)送模塊一直未能將發(fā)送緩沖區(qū)的數(shù)據(jù)發(fā)送到服務(wù)器澄者,這樣會導(dǎo)致發(fā)送緩沖區(qū)的數(shù)據(jù)越來越多笆呆。因此我們必須為發(fā)送緩沖區(qū)設(shè)定一個(gè)上限。此處需要說的是粱挡,如果緩沖區(qū)滿了之后的丟幀策略:丟幀必須整幀整幀的丟赠幕,不能丟半截;優(yōu)先丟時(shí)間戳更早的幀询筏;優(yōu)先丟非參考幀榕堰;如果參考幀被丟,那么到下一個(gè)參考幀之前的幀,全部需要丟掉逆屡。
網(wǎng)絡(luò)模塊可以失敗重連圾旨,但重連之后必須繼續(xù)重連之前的數(shù)據(jù)發(fā)送任務(wù)。發(fā)送成功的半幀數(shù)據(jù)魏蔗,視作發(fā)送失敗砍的,需要重發(fā)。
流媒體服務(wù)器端的優(yōu)化莺治。
流媒體服務(wù)器廓鞠,需要將收到的數(shù)據(jù)進(jìn)行分發(fā)。數(shù)據(jù)接收部分谣旁,流媒體服務(wù)器是被動的床佳,除了實(shí)做方式的優(yōu)化,理論上的可用的改進(jìn)基本沒有蔓挖。
流媒體服務(wù)器的數(shù)據(jù)分發(fā)夕土,是由播放器端主動請求發(fā)起的馆衔。那么服務(wù)器端需要處理的問題是瘟判,在播放器端的網(wǎng)絡(luò)不穩(wěn)定的情況下,播放器能夠隨時(shí)獲取到之前因?yàn)榫W(wǎng)絡(luò)故障而未能獲取到的數(shù)據(jù)角溃。因此拷获,流媒體服務(wù)器端,也需要有緩存的數(shù)據(jù)减细。
流媒體服務(wù)器端匆瓜,收到來自于編碼端的數(shù)據(jù)之后,需要能夠以幀或者GOP為單位來管理和視頻未蝌。從而避免緩存了半幀數(shù)據(jù)驮吱,或者發(fā)送半幀數(shù)據(jù)這種事情。播放器端的優(yōu)化萧吠。
播放器端播放數(shù)據(jù)左冬,需要按照時(shí)間戳播放。避免在數(shù)據(jù)本身正常而因?yàn)椴シ哦鴮?dǎo)致的不均勻纸型。
播放器端拇砰,需要加入緩存,避免服務(wù)器端的數(shù)據(jù)不均勻或者偶然的網(wǎng)絡(luò)故障狰腌。
數(shù)據(jù)播放時(shí)除破,并不需要緩存區(qū)被填滿之后才開始進(jìn)行解碼播放。比如琼腔,我們有20秒的接收緩存瑰枫。那么我們可以這么做,當(dāng)緩沖區(qū)的數(shù)據(jù)丹莲,不足8秒鐘時(shí)光坝,我們就可以開始進(jìn)行播放剖毯,但播放時(shí),我們進(jìn)行略微的減速播放(比如教馆,以時(shí)間戳的播放速率的0.9倍速度進(jìn)行播放)逊谋。如果緩沖區(qū)的數(shù)據(jù)超過了12秒鐘,那么我們可以加速播放(如正常速率的1.1倍速率)土铺。這樣的話胶滋,我們的緩存區(qū)的數(shù)據(jù),基本會維持有10秒鐘左右的內(nèi)容悲敷。那么這樣的話究恤,我們在媒體數(shù)據(jù)中斷10秒鐘之后,依舊可以正常播放后德,只要媒體數(shù)據(jù)在10秒鐘之內(nèi)恢復(fù)部宿,那么我們依舊可以無縫切換到正常狀態(tài)。并且瓢湃,用戶開始播放時(shí)理张,我們不會因?yàn)榫彺娑泻艽蟮牡却龝r(shí)間,而是立即開始播放绵患。
如果收到數(shù)據(jù)的速度遠(yuǎn)超過播放速度雾叭,以至于緩沖區(qū)不夠時(shí),丟幀策略和編碼發(fā)送端一致落蝙。
如果長時(shí)間沒有收到任何數(shù)據(jù)织狐,可以播放一些其它內(nèi)容告知用戶網(wǎng)絡(luò)故障。當(dāng)數(shù)據(jù)恢復(fù)時(shí)筏勒,需要從參考幀開始播放移迫,避免第一幀出現(xiàn)馬賽克。
直播系統(tǒng)的核心競爭力就是視頻的流暢性管行、清晰度厨埋、時(shí)延。而其中以流暢性至關(guān)重要病瞳,特別是在惡劣情況下的流暢性揽咕,更加重要。如何去保證視頻的流暢性套菜,以上幾點(diǎn)是否做到很關(guān)鍵亲善,而這些是否能夠方便可靠的實(shí)現(xiàn),也是上傳下載協(xié)議選擇的重要參考標(biāo)準(zhǔn)逗柴。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蛹头,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌渣蜗,老刑警劉巖屠尊,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異耕拷,居然都是意外死亡讼昆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進(jìn)店門骚烧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來浸赫,“玉大人,你說我怎么就攤上這事赃绊〖认浚” “怎么了?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵碧查,是天一觀的道長运敢。 經(jīng)常有香客問我,道長忠售,這世上最難降的妖魔是什么传惠? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮档痪,結(jié)果婚禮上涉枫,老公的妹妹穿的比我還像新娘。我一直安慰自己腐螟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布困后。 她就那樣靜靜地躺著乐纸,像睡著了一般。 火紅的嫁衣襯著肌膚如雪摇予。 梳的紋絲不亂的頭發(fā)上汽绢,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機(jī)與錄音侧戴,去河邊找鬼宁昭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛酗宋,可吹牛的內(nèi)容都是我干的积仗。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蜕猫,長吁一口氣:“原來是場噩夢啊……” “哼寂曹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤隆圆,失蹤者是張志新(化名)和其女友劉穎漱挚,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體渺氧,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旨涝,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了侣背。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片颊糜。...
    茶點(diǎn)故事閱讀 39,731評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖秃踩,靈堂內(nèi)的尸體忽然破棺而出衬鱼,到底是詐尸還是另有隱情,我是刑警寧澤憔杨,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布鸟赫,位于F島的核電站,受9級特大地震影響消别,放射性物質(zhì)發(fā)生泄漏抛蚤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一寻狂、第九天 我趴在偏房一處隱蔽的房頂上張望岁经。 院中可真熱鬧,春花似錦蛇券、人聲如沸缀壤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽塘慕。三九已至,卻和暖如春蒂胞,著一層夾襖步出監(jiān)牢的瞬間图呢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工骗随, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蛤织,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓鸿染,卻偏偏與公主長得像指蚜,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子牡昆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評論 2 354

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