日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深度解析工業(yè)級(jí)WebRTC應(yīng)用實(shí)踐

LiveVideoStack ? 來(lái)源:未知 ? 作者:胡薇 ? 2018-07-13 17:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

網(wǎng)易在音視頻領(lǐng)域有10多年豐富經(jīng)驗(yàn)的積累,在公司內(nèi)部我們把自己的這一套工業(yè)級(jí)的功能完整的音視頻技術(shù)方案稱為NRTC,NRTC的意思就是NetEase RTC。近幾年,WebRTC非?;馃?,尤其是2017年,蘋(píng)果宣布在Safari 11里面支持WebRTC,所以說(shuō)Web本身也變成了一個(gè)非常重要的入口,是音視頻很重要的一個(gè)終端,對(duì)于我們來(lái)說(shuō),要在我們的NRTC里面實(shí)現(xiàn)對(duì)WebRTC的支持,也就是要能夠支持Web這樣一個(gè)終端和入口。

1、NRTC技術(shù)解決方案

NRTC全稱為NetEase RTC,是網(wǎng)易公司實(shí)現(xiàn)的一套工業(yè)級(jí)的功能完整的音視頻技術(shù)解決方案。

1.1 NRTC技術(shù)架構(gòu)圖:

從架構(gòu)圖中,大家可以看到,我們有NRTC SDK,這是實(shí)時(shí)音視頻通話的客戶端SDK,有PC端、移動(dòng)端的SDK,另外有我們的NRTC MCU,這是一個(gè)媒體服務(wù)器。在客戶端上NRTC SDK會(huì)負(fù)責(zé)推拉流到NRTC MCU,NRTC MCU負(fù)責(zé)把媒體流中轉(zhuǎn)給其它的客戶端,同時(shí)它也會(huì)中轉(zhuǎn)給 NRTC BMS,BMS其實(shí)就是互動(dòng)直播服務(wù)器,在BMS上會(huì)做混音混屏,將音視頻混成一路流后再推給NRTC LVS,LVS就是直播源站,最后再推給我們的NCDN網(wǎng)絡(luò),通過(guò)NCDN的海量分發(fā),使用我們的NRTC Player就可以支持海量的用戶拉流。在這里面大家可以看到左半邊是UDP的方案,右半邊是一個(gè)TCP的方案,同時(shí)我們?cè)赟erver端有很多像錄制、混屏、混音、轉(zhuǎn)碼,包括存儲(chǔ),后續(xù)還有基于存儲(chǔ)的點(diǎn)播。

1.2 NRTC支持的功能:

實(shí)時(shí)音視頻通話

直播

互動(dòng)直播

點(diǎn)播

互動(dòng)白板

短視頻

1.3 音視頻技術(shù)棧

信令: SDP、JSEP、SIP、Jingle、ROAP

傳輸: RTP、RTCP、DTLS、RTMP、FLV、HLS

P2P: ICE、STUN、TURN、NAT

網(wǎng)絡(luò): UDP、TCP

音頻: Opus、G711、AAC、Speex、3A

視頻: H264、VP8

QoS: FEC、NACK、BWE

Server: SFU、MCU

端: Capture、Render、各種適配

2、怎樣理解WebRTC?

WebRTC是由W3C和IETF定義的規(guī)范,簡(jiǎn)單來(lái)講,就是一個(gè)在瀏覽器里面去實(shí)現(xiàn)音視頻會(huì)話的框架(JavaScript API),它不需要安裝,可以滿足P2P傳輸。只要通過(guò)信令的協(xié)商,也可以和傳統(tǒng)的音視頻應(yīng)用去做互聯(lián)互通。另外,WebRTC也是一個(gè)開(kāi)源項(xiàng)目,是由谷歌公司提供的基于C++的可以跨平臺(tái)的開(kāi)源的音視頻框架,是功能完整的一個(gè)音視頻SDK,一般用libwebrtc來(lái)表示這個(gè)開(kāi)源項(xiàng)目。

2.1 WebRTC的體系結(jié)構(gòu)

在這個(gè)簡(jiǎn)單的架構(gòu)里面,主要包括了網(wǎng)絡(luò)傳輸、音頻引擎、視頻引擎,,它主要的功能和內(nèi)容其實(shí)是C++實(shí)現(xiàn)的,然后封裝了一層JavaScript的API,讓你用JavaScript能夠調(diào)用到這些功能。

2.2 WebRTC的特點(diǎn)和局限

通過(guò)JavaScript的API在瀏覽器上調(diào)用

沒(méi)有定義信令

基于客戶端,沒(méi)有SFU/MCU

完全基于標(biāo)準(zhǔn)

依賴瀏覽器來(lái)實(shí)現(xiàn)

2.3 如何使用WebRTC

1)方法一:基于JavaScript的API進(jìn)行音視頻的應(yīng)用

完全基于JavaScrip去做,沒(méi)有媒體相關(guān)的Server,可靠性或者功能會(huì)很受限,但可以控制很低的成本。

2)方法二:基于libwebrtc來(lái)實(shí)現(xiàn)

由于WebRTC本身這些C++的Code,沒(méi)有很好的工程化,所以在異常保護(hù),錯(cuò)誤恢復(fù)等方面做得不太夠。在真實(shí)的應(yīng)用當(dāng)中,可能要做很多的調(diào)整和改造。

3)方法三:兼容、支持WebRTC

對(duì)于一些有成熟的音視頻框架體系的公司,可以在自己的體系上來(lái)兼容、支持WebRTC。

2.4 NRTC和WebRTC的比較

NRTC早于WebRTC

NRTC是VoIP的完整解決方案,大概可以說(shuō)NRTC SDK約等于WebRTC

NRTC的實(shí)現(xiàn)更靈活,WebRTC是基于標(biāo)準(zhǔn)的,有很多受限的方面

NRTC是工業(yè)級(jí)的實(shí)現(xiàn),技術(shù)框架更加成熟

3、如何實(shí)現(xiàn)NRTC支持WebRTC

3.1 在NRTC中連接WebRTC的原理

從圖中的簡(jiǎn)要架構(gòu)設(shè)計(jì)可以看出,如果想要NRTC的技術(shù)方案和Web端建立連接,可以通過(guò)WebRTC Gateway這種方式,WebRTC GateWay跟NRTC MCU之間是通過(guò)UDP協(xié)議傳輸NPDU的流媒體,另一端通過(guò)SRTP連接Web。

下面給大家講解一下WebRTC GateWay:

在WebRTC GateWay里面主要包括兩部分:信令和媒體,在信令方面,我們主要提供了WebSocket,信令是為了幫助兩個(gè)端SDP和ICE去交互,由提供的WebSocket來(lái)進(jìn)行連接;在媒體方面,要實(shí)現(xiàn)ICE框架和SRTP協(xié)議棧來(lái)建立網(wǎng)絡(luò)通訊的連接,還要做一個(gè)包的轉(zhuǎn)封裝工作,把RTP的包和NPDU的包相互轉(zhuǎn)換。有了這個(gè)WebRTC GateWay,經(jīng)過(guò)我們的MCU就可以跟我們的其他的端實(shí)現(xiàn)互聯(lián)互通。

3.2 實(shí)現(xiàn)NRTC兼容WebRTC所做的工作

實(shí)現(xiàn)瀏覽器的兼容

建立ICE框架

搭建RCTP協(xié)議棧,得到反饋值

確保Web端的可靠連接

擁塞控制

3.3 瀏覽器的“坑點(diǎn)”

1)利用adapter.js來(lái)實(shí)現(xiàn)瀏覽器的兼容

各種不同版本的瀏覽器實(shí)現(xiàn)這個(gè)規(guī)范的時(shí)候可能會(huì)接口會(huì)有些不一樣,主要還是接口層的不一樣,通過(guò)adapter.js可以兼容這些接口。

2)視頻分辨率

有些瀏覽器支持視頻分辨率的裁切,有些不支持。

3)媒體流的生命周期

瀏覽器上的媒體流的生命周期有限,有時(shí)得到的媒體是沒(méi)有視頻或音頻。

4)請(qǐng)求得到用戶媒體成功,卻沒(méi)有媒體流發(fā)過(guò)來(lái)。

3.4 Lite ICE框架

在ICE框架中包括NAT,STUN-RFC5389,TURN-RFC5766,ICE-RFC5245,TCP。在一個(gè)高可靠的網(wǎng)絡(luò)連接中,還要能夠支持TCP連接。當(dāng)一方是Serve且有固定的公網(wǎng)IP,另外一方是客戶端的這種情況下,可以使用Lite ICE框架。在Lite ICE這種情況下面,你只要給一個(gè)Host candidates,即當(dāng)你的Server回來(lái),給Server一個(gè)公網(wǎng)IP,不需要再去其他的探測(cè),你只要給Server的Host candidates就可以了,在Lite ICE情況下面,是有Full peer這端會(huì)發(fā)起連通的檢查,也就是由瀏覽器這一端發(fā)起連通檢查,它只需要兩步就可以完成連通檢查。

3.5 網(wǎng)絡(luò)監(jiān)測(cè)

1)在信令中,WebSocket有斷網(wǎng)事件通知

2)RTCPeerConnection有斷網(wǎng)事件通知

3)在TCP連接上,有基于signaling channel的keepalive

3.6 斷開(kāi)重連

1)Start over

Detach stream,銷毀現(xiàn)有連接等

信令連接、鑒權(quán)、媒體連接

2)ICE restart

3.7 Multiplexing and bundle

減少UDP的連接數(shù)

減少UDP的連接有兩個(gè)好處,第一,可以減少建立連接的時(shí)間,第二,在企業(yè)環(huán)境里面,很多UDP的一個(gè)端口連接需要找網(wǎng)管去配的,如果有多個(gè)連接,會(huì)加大配置和維護(hù)的難度。

3.8 丟包恢復(fù)和擁塞控制

1)GCC

GCC是在WebRTC本身現(xiàn)有的一套擁塞控制框架,它是有兩種模型,一種是基于丟包的模型,一種是基于時(shí)延的模型,從圖中可以看出,發(fā)送端有一個(gè)叫丟包的模型,在接收端有一個(gè)基于時(shí)延的模型(在最新的WebRTC里已調(diào)整為都在發(fā)送端了);在發(fā)送端它會(huì)做帶寬評(píng)估,評(píng)估管理以后流媒體送到接收端,那接收端之它有個(gè)基于延時(shí)的一個(gè)帶寬評(píng)估,評(píng)估完以后,當(dāng)它發(fā)現(xiàn)這個(gè)帶寬受限,或者它需要調(diào)整碼率,它通過(guò)REMB將消息送給發(fā)送端,讓發(fā)送端重新調(diào)整碼率,從而來(lái)實(shí)現(xiàn)一個(gè)帶寬評(píng)估和自適應(yīng)碼率的過(guò)程。

2)如何在WebRTC GateWay中讓GCC工作起來(lái)

REMB

先在接收端進(jìn)行一個(gè)最大接收碼率估測(cè),在WebRTC Gateway上通過(guò)REMB消息,告訴發(fā)送端如何調(diào)整碼率和帶寬。

GCC feedbacks

通過(guò)反饋給Delay-based controller正確的Transport cc來(lái)讓它計(jì)算正確的時(shí)延估計(jì),以及帶寬評(píng)估;通過(guò)反饋Loss-based controller兩種RTCP的報(bào)文(SR/RR),來(lái)進(jìn)行丟包的計(jì)算。

3)丟包重傳(NACK)

實(shí)現(xiàn)一個(gè)雙向的丟包重傳,通過(guò)WebRTC GateWay和瀏覽器之間 發(fā)送NACK的RTCP feedback信息來(lái)進(jìn)行丟包重傳。

3.9 分享一個(gè)SDP的例子

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • RTC
    RTC
    +關(guān)注

    關(guān)注

    2

    文章

    667

    瀏覽量

    72248
  • WebRTC
    +關(guān)注

    關(guān)注

    0

    文章

    57

    瀏覽量

    11972

原文標(biāo)題:網(wǎng)易工業(yè)級(jí)WebRTC應(yīng)用實(shí)踐深度解析

文章出處:【微信號(hào):livevideostack,微信公眾號(hào):LiveVideoStack】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深度解析 | 低抖動(dòng)高精度EtherCAT多軸控制的實(shí)現(xiàn)與實(shí)踐案例

    深度解析 | 低抖動(dòng)高精度EtherCAT多軸控制的實(shí)現(xiàn)與實(shí)踐案例 在工業(yè)自動(dòng)化領(lǐng)域,運(yùn)動(dòng)控制的精度和穩(wěn)定性直接決定了生產(chǎn)效率和產(chǎn)品質(zhì)量。其中EtherCAT多軸控制技術(shù)尤為引人注
    發(fā)表于 12-09 17:17

    4G工業(yè)路由器與普通路由器區(qū)別深度解析

    `  4G工業(yè)路由器與普通路由器區(qū)別深度解析  4G工業(yè)路由器可幫助用戶快速接入高速互聯(lián)網(wǎng),實(shí)現(xiàn)安全可靠的數(shù)據(jù)傳輸,廣泛應(yīng)用于交通、電力、金融、水利、氣象、環(huán)保、
    發(fā)表于 03-15 16:51

    機(jī)器學(xué)習(xí)實(shí)踐指南——案例應(yīng)用解析

    機(jī)器學(xué)習(xí)實(shí)踐指南——案例應(yīng)用解析
    發(fā)表于 04-13 16:40

    解析深度學(xué)習(xí):卷積神經(jīng)網(wǎng)絡(luò)原理與視覺(jué)實(shí)踐

    解析深度學(xué)習(xí):卷積神經(jīng)網(wǎng)絡(luò)原理與視覺(jué)實(shí)踐
    發(fā)表于 06-14 22:21

    WebRTC的視頻部分有哪些功能?

    WebRTC的視頻部分有哪些功能?PTP/RTCP工作流程是怎樣的?
    發(fā)表于 06-15 07:31

    AUTOSAR架構(gòu)深度解析 精選資料推薦

    AUTOSAR架構(gòu)深度解析本文轉(zhuǎn)載于:AUTOSAR架構(gòu)深度解析目錄AUTOSAR架構(gòu)深度解析A
    發(fā)表于 07-28 07:40

    AUTOSAR架構(gòu)深度解析 精選資料分享

    AUTOSAR架構(gòu)深度解析本文轉(zhuǎn)載于:AUTOSAR架構(gòu)深度解析AUTOSAR的分層式設(shè)計(jì),用于支持完整的軟件和硬件模塊的獨(dú)立性(Independence),中間RTE(Runtime
    發(fā)表于 07-28 07:02

    WebRTC技術(shù)的應(yīng)用

    我們這里常說(shuō)的RTC可以理解為WebRTC技術(shù),因?yàn)?b class='flag-5'>WebRTC技術(shù)是目前使用最廣泛的即時(shí)通信技術(shù),雖然在早期我們提到WebRTC、提到視頻通話就會(huì)想到P2P的方式,但實(shí)際的視頻通話方式背后的邏輯有
    發(fā)表于 11-01 07:42

    WebRTC有哪些功能

    WebRTC 本身提供的是 1 對(duì) 1 的通信模型,在 STUN/TURN 的輔助下,如果能實(shí)現(xiàn) NAT 穿越,那么兩個(gè)瀏覽器是可以直接進(jìn)行媒體數(shù)據(jù)交換的;如果不能實(shí)現(xiàn) NAT 穿越,那么只能通過(guò)
    發(fā)表于 11-03 08:16

    什么是WebRTC

    什么是WebRTCWebRTC,即Web Real-Time Communication(網(wǎng)頁(yè)即時(shí)通信)。它是一個(gè)開(kāi)源項(xiàng)目,旨在創(chuàng)建簡(jiǎn)單、標(biāo)準(zhǔn)化的流程通過(guò)Web提供實(shí)時(shí)通信(RTC)。WebRTC
    發(fā)表于 12-09 07:59

    如何使用WebRTC?

    SRS 4.0與WebRTC音視頻通話1.音視頻高薪崗位都需要什么技能點(diǎn)2.WebRTC的技術(shù)點(diǎn)分析3.SRS4.0如何使用WebRTC視頻講解如下,點(diǎn)擊觀看:流媒體服務(wù)器開(kāi)發(fā)——SRS 4.0
    發(fā)表于 12-24 06:40

    C語(yǔ)言深度解析

    C語(yǔ)言深度解析,本資料來(lái)源于網(wǎng)絡(luò),對(duì)C語(yǔ)言的學(xué)習(xí)有很大的幫助,有著較為深刻的解析,可能會(huì)對(duì)讀者有一定的幫助。
    發(fā)表于 09-28 07:00

    WebRTC技術(shù)服務(wù)商:預(yù)測(cè)2018年WebRTC的5大趨勢(shì)

    也許對(duì)于大部分WebRTC的開(kāi)發(fā)者而言,2018年將是忙碌的一年。主流瀏覽器和蘋(píng)果官方支持,標(biāo)準(zhǔn)和API定型,WebRTC生態(tài)具備了快速發(fā)展的條件。WebRTC技術(shù)服務(wù)商“WebRTC
    的頭像 發(fā)表于 01-16 12:51 ?6579次閱讀

    使用WebRTC開(kāi)發(fā)Android Messenger的方法解析

    WebRTC是一種開(kāi)放源代碼視頻會(huì)議解決方案,可用于各種軟件。包括瀏覽器,消息客戶端和流媒體服務(wù)。
    的頭像 發(fā)表于 09-08 09:35 ?2043次閱讀

    聚徽深度解析國(guó)內(nèi)工控平板電腦的工業(yè)級(jí)抗干擾技術(shù)如何實(shí)現(xiàn)?

    工業(yè)自動(dòng)化與智能制造領(lǐng)域,工控平板電腦作為核心人機(jī)交互終端,其抗干擾能力直接決定了生產(chǎn)系統(tǒng)的穩(wěn)定性與可靠性。國(guó)內(nèi)廠商通過(guò)技術(shù)創(chuàng)新與場(chǎng)景適配,構(gòu)建了從硬件設(shè)計(jì)到軟件優(yōu)化的全鏈路抗干擾體系。本文將從技術(shù)原理、硬件架構(gòu)、軟件策略及場(chǎng)景驗(yàn)證四個(gè)維度,深度
    的頭像 發(fā)表于 07-11 18:11 ?1044次閱讀
    施甸县| 永泰县| 米林县| 抚顺市| 柳州市| 鲁山县| 锡林郭勒盟| 望城县| 宜丰县| 轮台县| 松溪县| 濮阳县| 高碑店市| 惠东县| 康乐县| 永安市| 大邑县| 中卫市| 诸暨市| 宁乡县| 汕尾市| 华坪县| 昭苏县| 宣武区| 邵武市| 旌德县| 如东县| 法库县| 孝义市| 金平| 黑山县| 彭阳县| 大关县| 宁陵县| 偏关县| 桂林市| 澎湖县| 静安区| 蕲春县| 个旧市| 东台市|