精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深度解析工業級WebRTC應用實踐

LiveVideoStack ? 來源:未知 ? 作者:胡薇 ? 2018-07-13 17:56 ? 次閱讀

網易在音視頻領域有10多年豐富經驗的積累,在公司內部我們把自己的這一套工業級的功能完整的音視頻技術方案稱為NRTC,NRTC的意思就是NetEase RTC。近幾年,WebRTC非常火熱,尤其是2017年,蘋果宣布在Safari 11里面支持WebRTC,所以說Web本身也變成了一個非常重要的入口,是音視頻很重要的一個終端,對于我們來說,要在我們的NRTC里面實現對WebRTC的支持,也就是要能夠支持Web這樣一個終端和入口。

1、NRTC技術解決方案

NRTC全稱為NetEase RTC,是網易公司實現的一套工業級的功能完整的音視頻技術解決方案。

1.1 NRTC技術架構圖:

從架構圖中,大家可以看到,我們有NRTC SDK,這是實時音視頻通話的客戶端SDK,有PC端、移動端的SDK,另外有我們的NRTC MCU,這是一個媒體服務器。在客戶端上NRTC SDK會負責推拉流到NRTC MCU,NRTC MCU負責把媒體流中轉給其它的客戶端,同時它也會中轉給 NRTC BMS,BMS其實就是互動直播服務器,在BMS上會做混音混屏,將音視頻混成一路流后再推給NRTC LVS,LVS就是直播源站,最后再推給我們的NCDN網絡,通過NCDN的海量分發,使用我們的NRTC Player就可以支持海量的用戶拉流。在這里面大家可以看到左半邊是UDP的方案,右半邊是一個TCP的方案,同時我們在Server端有很多像錄制、混屏、混音、轉碼,包括存儲,后續還有基于存儲的點播。

1.2 NRTC支持的功能:

實時音視頻通話

直播

互動直播

點播

互動白板

短視頻

1.3 音視頻技術棧

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

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

P2P: ICE、STUN、TURN、NAT

網絡: UDP、TCP

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

視頻: H264、VP8

QoS: FEC、NACK、BWE

Server: SFU、MCU

端: Capture、Render、各種適配

2、怎樣理解WebRTC?

WebRTC是由W3C和IETF定義的規范,簡單來講,就是一個在瀏覽器里面去實現音視頻會話的框架(JavaScript API),它不需要安裝,可以滿足P2P傳輸。只要通過信令的協商,也可以和傳統的音視頻應用去做互聯互通。另外,WebRTC也是一個開源項目,是由谷歌公司提供的基于C++的可以跨平臺的開源的音視頻框架,是功能完整的一個音視頻SDK,一般用libwebrtc來表示這個開源項目。

2.1 WebRTC的體系結構

在這個簡單的架構里面,主要包括了網絡傳輸、音頻引擎、視頻引擎,,它主要的功能和內容其實是C++實現的,然后封裝了一層JavaScript的API,讓你用JavaScript能夠調用到這些功能。

2.2 WebRTC的特點和局限

通過JavaScript的API在瀏覽器上調用

沒有定義信令

基于客戶端,沒有SFU/MCU

完全基于標準

依賴瀏覽器來實現

2.3 如何使用WebRTC

1)方法一:基于JavaScript的API進行音視頻的應用

完全基于JavaScrip去做,沒有媒體相關的Server,可靠性或者功能會很受限,但可以控制很低的成本。

2)方法二:基于libwebrtc來實現

由于WebRTC本身這些C++的Code,沒有很好的工程化,所以在異常保護,錯誤恢復等方面做得不太夠。在真實的應用當中,可能要做很多的調整和改造。

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

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

2.4 NRTC和WebRTC的比較

NRTC早于WebRTC

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

NRTC的實現更靈活,WebRTC是基于標準的,有很多受限的方面

NRTC是工業級的實現,技術框架更加成熟

3、如何實現NRTC支持WebRTC

3.1 在NRTC中連接WebRTC的原理

從圖中的簡要架構設計可以看出,如果想要NRTC的技術方案和Web端建立連接,可以通過WebRTC Gateway這種方式,WebRTC GateWay跟NRTC MCU之間是通過UDP協議傳輸NPDU的流媒體,另一端通過SRTP連接Web。

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

在WebRTC GateWay里面主要包括兩部分:信令和媒體,在信令方面,我們主要提供了WebSocket,信令是為了幫助兩個端SDP和ICE去交互,由提供的WebSocket來進行連接;在媒體方面,要實現ICE框架和SRTP協議棧來建立網絡通訊的連接,還要做一個包的轉封裝工作,把RTP的包和NPDU的包相互轉換。有了這個WebRTC GateWay,經過我們的MCU就可以跟我們的其他的端實現互聯互通。

3.2 實現NRTC兼容WebRTC所做的工作

實現瀏覽器的兼容

建立ICE框架

搭建RCTP協議棧,得到反饋值

確保Web端的可靠連接

擁塞控制

3.3 瀏覽器的“坑點”

1)利用adapter.js來實現瀏覽器的兼容

各種不同版本的瀏覽器實現這個規范的時候可能會接口會有些不一樣,主要還是接口層的不一樣,通過adapter.js可以兼容這些接口。

2)視頻分辨率

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

3)媒體流的生命周期

瀏覽器上的媒體流的生命周期有限,有時得到的媒體是沒有視頻或音頻。

4)請求得到用戶媒體成功,卻沒有媒體流發過來。

3.4 Lite ICE框架

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

3.5 網絡監測

1)在信令中,WebSocket有斷網事件通知

2)RTCPeerConnection有斷網事件通知

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

3.6 斷開重連

1)Start over

Detach stream,銷毀現有連接等

信令連接、鑒權、媒體連接

2)ICE restart

3.7 Multiplexing and bundle

減少UDP的連接數

減少UDP的連接有兩個好處,第一,可以減少建立連接的時間,第二,在企業環境里面,很多UDP的一個端口連接需要找網管去配的,如果有多個連接,會加大配置和維護的難度。

3.8 丟包恢復和擁塞控制

1)GCC

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

2)如何在WebRTC GateWay中讓GCC工作起來

REMB

先在接收端進行一個最大接收碼率估測,在WebRTC Gateway上通過REMB消息,告訴發送端如何調整碼率和帶寬。

GCC feedbacks

通過反饋給Delay-based controller正確的Transport cc來讓它計算正確的時延估計,以及帶寬評估;通過反饋Loss-based controller兩種RTCP的報文(SR/RR),來進行丟包的計算。

3)丟包重傳(NACK)

實現一個雙向的丟包重傳,通過WebRTC GateWay和瀏覽器之間 發送NACK的RTCP feedback信息來進行丟包重傳。

3.9 分享一個SDP的例子

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • RTC
    RTC
    +關注

    關注

    2

    文章

    529

    瀏覽量

    66314
  • WebRTC
    +關注

    關注

    0

    文章

    56

    瀏覽量

    11216

原文標題:網易工業級WebRTC應用實踐深度解析

文章出處:【微信號:livevideostack,微信公眾號:LiveVideoStack】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    4G工業路由器與普通路由器區別深度解析

    `  4G工業路由器與普通路由器區別深度解析  4G工業路由器可幫助用戶快速接入高速互聯網,實現安全可靠的數據傳輸,廣泛應用于交通、電力、金融、水利、氣象、環保、
    發表于 03-15 16:51

    機器學習實踐指南——案例應用解析

    機器學習實踐指南——案例應用解析
    發表于 04-13 16:40

    解析深度學習:卷積神經網絡原理與視覺實踐

    解析深度學習:卷積神經網絡原理與視覺實踐
    發表于 06-14 22:21

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

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

    AUTOSAR架構深度解析 精選資料推薦

    AUTOSAR架構深度解析本文轉載于:AUTOSAR架構深度解析目錄AUTOSAR架構深度解析A
    發表于 07-28 07:40

    AUTOSAR架構深度解析 精選資料分享

    AUTOSAR架構深度解析本文轉載于:AUTOSAR架構深度解析AUTOSAR的分層式設計,用于支持完整的軟件和硬件模塊的獨立性(Independence),中間RTE(Runtime
    發表于 07-28 07:02

    WebRTC技術的應用

    我們這里常說的RTC可以理解為WebRTC技術,因為WebRTC技術是目前使用最廣泛的即時通信技術,雖然在早期我們提到WebRTC、提到視頻通話就會想到P2P的方式,但實際的視頻通話方式背后的邏輯有
    發表于 11-01 07:42

    WebRTC有哪些功能

    WebRTC 本身提供的是 1 對 1 的通信模型,在 STUN/TURN 的輔助下,如果能實現 NAT 穿越,那么兩個瀏覽器是可以直接進行媒體數據交換的;如果不能實現 NAT 穿越,那么只能通過
    發表于 11-03 08:16

    什么是WebRTC

    什么是WebRTCWebRTC,即Web Real-Time Communication(網頁即時通信)。它是一個開源項目,旨在創建簡單、標準化的流程通過Web提供實時通信(RTC)。WebRTC
    發表于 12-09 07:59

    如何使用WebRTC

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

    C語言深度解析

    C語言深度解析,本資料來源于網絡,對C語言的學習有很大的幫助,有著較為深刻的解析,可能會對讀者有一定的幫助。
    發表于 09-28 07:00

    WebRTC技術服務商:預測2018年WebRTC的5大趨勢

    也許對于大部分WebRTC的開發者而言,2018年將是忙碌的一年。主流瀏覽器和蘋果官方支持,標準和API定型,WebRTC生態具備了快速發展的條件。WebRTC技術服務商“WebRTC
    的頭像 發表于 01-16 12:51 ?5915次閱讀

    使用WebRTC開發Android Messenger的方法解析

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

    HarmonyOS 測試技術與實踐-一快速掌握專業的系統/設備深度驗證

    HDC 2021華為開發者分論壇HarmonyOS 測試技術與實踐-一快速掌握專業的系統/設備深度驗證
    的頭像 發表于 10-23 14:34 ?1093次閱讀
    HarmonyOS 測試技術與<b class='flag-5'>實踐</b>-一快速掌握專業<b class='flag-5'>級</b>的系統/設備<b class='flag-5'>深度</b>驗證

    串口服務器在工業控制領域的應用:深度解析與前沿實踐

    深度解析串口服務器在工業控制領域的應用,并探討其前沿實踐。 一、串口服務器的核心作用 串口服務器,簡單來說,是一種將串行通信轉換為網絡通信的設備。它可以將傳統的RS-232、RS-42
    的頭像 發表于 05-21 16:50 ?445次閱讀