詳解IOS WebRTC的實(shí)現(xiàn)原理
它在2011年5月開放了工程的源代碼,在行業(yè)內(nèi)得到了廣泛的支持和應(yīng)用,成為下一代視頻通話的標(biāo)準(zhǔn)。
WebRTC的音視頻通信是基于P2P,那么什么是P2P呢?
它是點(diǎn)對(duì)點(diǎn)連接的英文縮寫。
P2P連接模式一般我們傳統(tǒng)的連接方式,都是以服務(wù)器為中介的模式:
類似http協(xié)議:客戶端?服務(wù)端(當(dāng)然這里服務(wù)端返回的箭頭僅僅代表返回請(qǐng)求數(shù)據(jù))。
我們?cè)谶M(jìn)行即時(shí)通訊時(shí),進(jìn)行文字、圖片、錄音等傳輸?shù)臅r(shí)候:客戶端A?服務(wù)器?客戶端B。
而點(diǎn)對(duì)點(diǎn)的連接恰恰數(shù)據(jù)通道一旦形成,中間是不經(jīng)過服務(wù)端的,數(shù)據(jù)直接從一個(gè)客戶端流向另一個(gè)客戶端:
客戶端A?客戶端B ... 客戶端A?客戶端C ...(可以無數(shù)個(gè)客戶端之間互聯(lián))
這里可以想想音視頻通話的應(yīng)用場(chǎng)景,我們服務(wù)端確實(shí)是沒必要去獲取兩者通信的數(shù)據(jù),而且這樣做有一個(gè)最大的一個(gè)優(yōu)點(diǎn)就是,大大的減輕了服務(wù)端的壓力。
而WebRTC就是這樣一個(gè)基于P2P的音視頻通信技術(shù)。
WebRTC的服務(wù)器與信令講到這里,可能大家覺得WebRTC就不需要服務(wù)端了么?這是顯然是錯(cuò)誤的認(rèn)識(shí),嚴(yán)格來說它僅僅是不需要服務(wù)端來進(jìn)行數(shù)據(jù)中轉(zhuǎn)而已。
WebRTC提供了瀏覽器到瀏覽器(點(diǎn)對(duì)點(diǎn))之間的通信,但并不意味著WebRTC不需要服務(wù)器。暫且不說基于服務(wù)器的一些擴(kuò)展業(yè)務(wù),WebRTC至少有兩件事必須要用到服務(wù)器:
瀏覽器之間交換建立通信的元數(shù)據(jù)(信令)必須通過服務(wù)器。 為了穿越NAT和防火墻。第1條很好理解,我們?cè)贏和B需要建立P2P連接的時(shí)候,至少要服務(wù)器來協(xié)調(diào),來控制連接開始建立。而連接斷開的時(shí)候,也需要服務(wù)器來告知另一端P2P連接已斷開。這些我們用來控制連接的狀態(tài)的數(shù)據(jù)稱之為信令,而這個(gè)與服務(wù)端連接的通道,對(duì)于WebRTC而言就是信令通道。
圖中signalling就是往服務(wù)端發(fā)送信令,然后底層調(diào)用WebRTC,WebRTC通過服務(wù)端得到的信令,得知通信對(duì)方的基本信息,從而實(shí)現(xiàn)虛線部分Media通信連接。
當(dāng)然信令能做的事還有很多,這里大概列了一下:
用來控制通信開啟或者關(guān)閉的連接控制消息 發(fā)生錯(cuò)誤時(shí)用來彼此告知的消息 媒體流元數(shù)據(jù),比如像解碼器、解碼器的配置、帶寬、媒體類型等等 用來建立安全連接的關(guān)鍵數(shù)據(jù) 外界所看到的的網(wǎng)絡(luò)上的數(shù)據(jù),比如IP地址、端口等在建立連接之前,客戶端之間顯然沒有辦法傳遞數(shù)據(jù)。所以我們需要通過服務(wù)器的中轉(zhuǎn),在客戶端之間傳遞這些數(shù)據(jù),然后建立客戶端之間的點(diǎn)對(duì)點(diǎn)連接。但是WebRTC API中并沒有實(shí)現(xiàn)這些,這些就需要我們來實(shí)現(xiàn)了。
而第2條中的NAT這個(gè)概念,參考文章iOS即時(shí)通訊,從入門到“放棄”?,中也提到過,不過是為了應(yīng)對(duì)NAT超時(shí),所造成的TCP連接中斷。在這里我們就不展開去講了,感興趣的可以看看:NAT百科
這里我簡要說明一下,NAT技術(shù)的出現(xiàn),其實(shí)就是為了解決IPV4下的IP地址匱乏。舉例來說,就是通常我們處在一個(gè)路由器之下,而路由器分配給我們的地址通常為192.168.0.1 、192.168.0.2如果有n個(gè)設(shè)備,可能分配到192.168.0.n,而這個(gè)IP地址顯然只是一個(gè)內(nèi)網(wǎng)的IP地址,這樣一個(gè)路由器的公網(wǎng)地址對(duì)應(yīng)了n個(gè)內(nèi)網(wǎng)的地址,通過這種使用少量的公有IP 地址代表較多的私有IP 地址的方式,將有助于減緩可用的IP地址空間的枯竭。
但是這也帶來了一系列的問題,例如這里點(diǎn)對(duì)點(diǎn)連接下,會(huì)導(dǎo)致這樣一個(gè)問題:
如果客戶端A想給客戶端B發(fā)送數(shù)據(jù),則數(shù)據(jù)來到客戶端B所在的路由器下,會(huì)被NAT阻攔,這樣B就無法收到A的數(shù)據(jù)了。
但是A的NAT此時(shí)已經(jīng)知道了B這個(gè)地址,所以當(dāng)B給A發(fā)送數(shù)據(jù)的時(shí)候,NAT不會(huì)阻攔,這樣A就可以收到B的數(shù)據(jù)了。這就是我們進(jìn)行NAT穿越的核心思路。
于是我們就有了以下思路:
我們借助一個(gè)公網(wǎng)IP服務(wù)器,a,b都往公網(wǎng)IP/PORT發(fā)包,公網(wǎng)服務(wù)器就可以獲知a,b的IP/PORT,又由于a,b主動(dòng)給公網(wǎng)IP服務(wù)器發(fā)包,所以公網(wǎng)服務(wù)器可以穿透NAT A,NAT B送包給a,b。
所以只要公網(wǎng)IP將b的IP/PORT發(fā)給a,a的IP/PORT發(fā)給b。這樣下次a和b互相消息,就不會(huì)被NAT阻攔了。
WebRTC的NAT/防火墻穿越技術(shù)基于上述的一個(gè)思路來實(shí)現(xiàn)的:
建立點(diǎn)對(duì)點(diǎn)信道的一個(gè)常見問題,就是NAT穿越技術(shù)。在處于使用了NAT設(shè)備的私有TCP/IP網(wǎng)絡(luò)中的主機(jī)之間需要建立連接時(shí)需要使用NAT穿越技術(shù)。以往在VoIP領(lǐng)域經(jīng)常會(huì)遇到這個(gè)問題。目前已經(jīng)有很多NAT穿越技術(shù),但沒有一項(xiàng)是完美的,因?yàn)镹AT的行為是非標(biāo)準(zhǔn)化的。這些技術(shù)中大多使用了一個(gè)公共服務(wù)器,這個(gè)服務(wù)使用了一個(gè)從全球任何地方都能訪問得到的IP地址。在RTCPeeConnection中,使用ICE框架來保證RTCPeerConnection能實(shí)現(xiàn)NAT穿越
這里提到了ICE協(xié)議框架,它大約是由以下幾個(gè)技術(shù)和協(xié)議組成的:STUN、NAT、TURN、SDP,這些協(xié)議技術(shù),幫助ICE共同實(shí)現(xiàn)了NAT/防火墻穿越。
以上就是詳解IOS WebRTC的實(shí)現(xiàn)原理的詳細(xì)內(nèi)容,更多關(guān)于IOS WebRTC的實(shí)現(xiàn)原理的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. XML入門精解之結(jié)構(gòu)與語法2. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera3. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)4. 利用CSS3新特性創(chuàng)建透明邊框三角5. XML入門的常見問題(一)6. HTML5 Canvas繪制圖形從入門到精通7. 概述IE和SQL2k開發(fā)一個(gè)XML聊天程序8. HTML <!DOCTYPE> 標(biāo)簽9. HTML DOM setInterval和clearInterval方法案例詳解10. XML入門的常見問題(二)
