WebRTC(五):TURN協議

TURN(Traversal Using Relays around NAT)協議是一個網絡協議,旨在解決 NAT(網絡地址轉換)和防火墻 環境下的 UDP/TCP通信問題。它通常與 STUN 和 ICE 協議一起使用,廣泛應用于 WebRTC、SIP 和視頻會議等實時通信場景中。

為什么需要 TURN?

  1. NAT 問題

NAT 會屏蔽內網客戶端的真實地址,使兩個處于不同 NAT 環境的客戶端 無法直接建立連接

  1. STUN 的局限

STUN 可以幫助客戶端獲取自己的公網 IP 和端口,但當:

  • 雙方都在對稱型 NAT 后面,
  • 或者存在嚴格的防火墻時,

STUN 穿透失敗,這時就需要 TURN。

工作原理

TURN 的基本思想是:

通過中繼服務器(TURN Server)轉發媒體流量,繞過 NAT/防火墻。

工作流程

  • 階段1:客戶端與 TURN Server 建立連接(Allocate)

    • Step 1.1:客戶端發起 Allocate 請求

      • 類型:Allocate Request
      • 內容:希望使用的傳輸協議(UDP/TCP)、Lifetime 等
      • 信令方式:基于 STUN over UDP/TCP
      Client A --> TURN Server
      Message: Allocate Request
      Attributes: REQUESTED-TRANSPORT=UDP
      
    • Step 1.2:TURN Server 分配中繼地址

      • 返回:Allocate Success Response

      • 包含字段:XOR-RELAYED-ADDRESS(中繼地址)、XOR-MAPPED-ADDRESS(客戶端映射地址)

      TURN Server --> Client A
      Message: Allocate Success
      XOR-RELAYED-ADDRESS: 203.0.113.1:54320  ← 中繼地址
      
  • 階段2:建立 Permission(通信授權)

    為了安全,TURN Server 默認不允許所有對端通信,必須顯式授權。

    • Step 2.1:CreatePermission 請求

      Client A --> TURN Server
      Message: CreatePermission
      XOR-PEER-ADDRESS: 對端 B 的公網地址
      
    • Step 2.2:成功響應

    • 若授權成功,返回 CreatePermission Success Response

    • 默認權限 300 秒失效

  • 階段3:數據通道建立(Send Indication 或 ChannelBind)

? TURN 支持兩種數據通道:

通道方式描述性能
Send/Receive Indication使用完整 STUN 消息發送數據靈活,開銷大
ChannelData映射通道編號,提高效率更快,推薦
  • Step 3.1:發送 ChannelBind 請求
Client A --> TURN Server
Message: ChannelBind
XOR-PEER-ADDRESS: Client B
CHANNEL-NUMBER: 0x4000-0x7FFF(客戶端分配)
  • Step 3.2:TURN Server 回復成功綁定

    • 之后,Client A 可以通過 ChannelData 消息直接發送媒體數據。
  • 階段4:媒體數據中繼傳輸

    • A → B 流程
    Client A --> TURN Server
    Message: ChannelData 或 Send Indication
    
    TURN Server --> Client B
    Message: UDP/TCP 數據包
    
    • B → A 反向流

      Client B --> TURN Server(發往分配的 relayed address)
      TURN Server --> Client A(通過 Channel 或 Data Indication)
      
  • 階段5:Refresh 保活

    • TURN allocation 默認 600秒過期

    • 客戶端需周期性發送 Refresh Request 保活

      Client A --> TURN Server
      Message: Refresh Request
      LIFETIME: 600
      

流程時序圖:

客戶端A                             TURN服務器                             客戶端B|                                    |                                      ||-------- Allocate Request --------->|                                      ||<------ Allocate Response ----------|                                      ||                                    |                                      ||--- CreatePermission (B的IP) ----->|                                      ||<--- CreatePermission Success ------|                                      ||                                    |                                      ||-------- ChannelBind (B的IP) ----->|                                      ||<----- ChannelBind Success ---------|                                      ||                                    |                                      ||---- ChannelData(B的數據) ------->|                                      ||                                    |-----> 轉發數據到 客戶端B ---------->||                                    |<----- 客戶端B發來響應數據 -----------||<--- ChannelData(返回數據) -------|                                      ||                                    |                                      ||--------- Refresh Request --------->|                                      ||<-------- Refresh Response ---------|                                      |

TURN 與 STUN、ICE 的關系

協議作用
STUN獲取公網地址,嘗試打洞
TURN中繼傳輸,保證連接
ICE綜合使用 STUN/TURN,選擇最優路徑(直接連接優先)

TURN 是一種最后手段,因為它會增加 延遲帶寬成本

協議詳解

協議標準

TURN 協議定義在以下 RFC 中:

  • RFC 5766:TURN 協議標準
  • RFC 5389:STUN 基礎
  • RFC 6062:支持 TCP 的 TURN
  • RFC 6156:IPv6 支持

通信流程詳細圖解

客戶端A ---------> TURN服務器 <--------- 客戶端BAllocate            Send IndicationRefresh             Data ChannelSend/Receive        Permissions

主要步驟:

  • Allocate Request:客戶端請求分配中繼地址;
  • Allocate Success Response:服務器返回一個公網 IP+端口(Relayed Address);
  • CreatePermission:允許某個對端向這個中繼地址發送數據;
  • Send Indication / Data Indication:發送或接收數據;
  • Refresh:保持分配有效(每300秒刷新);
  • Channel Bind(可選):綁定 Channel,降低通信成本;

消息結構(基于 STUN)

TURN 消息與 STUN 類似,由以下字段組成:

  • Message Type:請求/響應/指示類型
  • Transaction ID:用于匹配請求與響應
  • Attributes
    • XOR-RELAYED-ADDRESS:返回的中繼地址
    • LIFETIME:分配有效期
    • DATA:要中繼的實際數據
    • XOR-PEER-ADDRESS:目標地址

TURN Server 實現

常見開源 TURN Server:

名稱簡介
Coturn最流行的 TURN server,支持 STUN、TURN、TLS 等協議
restund輕量級實現
rfc5766-turn-server老舊項目,已被 Coturn 替代

Coturn 配置文件示例:

listening-port=3478
relay-ip=your_public_ip
realm=yourdomain.com
user=username:password

優缺點

優點:

  • 100% 可達性:即使雙方都在對稱 NAT 后,也能通信;
  • 標準化:已被 WebRTC、SIP 等廣泛采用;

缺點:

  • 服務器成本高:帶寬開銷大;
  • 延遲增加:所有流量都要繞行服務器;
  • 復雜度增加:協議較 STUN 更復雜;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/85757.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/85757.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/85757.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python 的內置函數 hasattr

Python 內建函數列表 > Python 的內置函數 hasattr Python 的內置函數 hasattr() 用于檢查一個對象是否具有指定的屬性或方法。該函數的語法為&#xff1a; hasattr(object, name)參數說明&#xff1a; object&#xff1a;要檢查的對象&#xff0c;可以是任何 Python 對象…

docker使用技巧之把擴展卷命名變成有意義

背景 之前使用別人的鏡像之后&#xff0c;啟動docker后發出現了一堆看不懂名稱的擴展卷 eg&#xff1a;集群查看 擴展卷查看 這個時候如果有很多集群需要清理擴展卷就很麻煩&#xff0c;不知道是哪個集群的 操作步驟 可以實現的分析&#xff1a;這個擴展卷的信息應該是和…

《博物通書》《博物新編》與滿清歷史篡改

《博物新編》作為近代西方科技輸入中國的首部著作&#xff0c;其問世猶如一顆投入平靜湖面的巨石&#xff0c;在 19 世紀中期的中國激起層層漣漪&#xff0c;對中國近代科學發展產生了多維度、深層次的影響。它不僅是知識傳播的載體&#xff0c;更是推動中國科學從傳統走向近代…

【入門】【例18.1】 睡眠

| 時間限制&#xff1a;C/C 1000MS&#xff0c;其他語言 2000MS 內存限制&#xff1a;C/C 64MB&#xff0c;其他語言 128MB 難度&#xff1a;中等 分數&#xff1a;100 OI排行榜得分&#xff1a;12(0.1分數2難度) 出題人&#xff1a;root | 描述 一個人只有每天睡眠時間到達 8…

DAY 38 Dataset和Dataloader類

知識點回顧&#xff1a; Dataset類的__getitem__和__len__方法&#xff08;本質是python的特殊方法&#xff09;Dataloader類minist手寫數據集的了解 作業&#xff1a;了解下cifar數據集&#xff0c;嘗試獲取其中一張圖片 import torch import torch.nn as nn import torch.o…

【Kubernetes】以LOL的視角打開K8s

前言 對于大部分后端程序員乃至于非后端程序員來說&#xff0c;在當前的云原生時代&#xff0c;Kubernetes&#xff08;后稱K8s&#xff09;都是繞不開的一項技術&#xff1b;同時&#xff0c;對于這個時代的程序員來說&#xff0c;“英雄聯盟”&#xff08;后稱LOL&#xff0…

UE5 游戲模板 —— FirstShootGame

UE5 游戲模板 —— FirstShootGame 前言一、GameMode二、組件1.ShooterPickUpComponent單播多播 2.ShooterWeaponComponent附著武器開火 3.小結4.ShooterProjectile初始化碰撞受擊檢測 三、Character初始化輸入移動 總結 前言 有了前兩個俯視角游戲的基礎讓我們來看看相對復雜…

國家級與省級(不含港澳臺)標準地圖服務網站匯總

在先前的文章中&#xff0c;介紹了部分省級的標準地圖服務網站可以下載各個區縣近幾年、不同要素的標準地圖&#xff08;鏈接&#xff1a;國家與省市縣 標準地圖服務網站 審圖號地圖下載&#xff09;&#xff0c;但是當時只匯總了部分省級的標準地圖服務網站。 這兩天看到了一個…

前端開發面試題總結-vue3框架篇(一)

文章目錄 Vue3高頻問答一、vue2/vue3中常用的構建工具和腳手架分別是什么? 有什么區別?二、請說一說vue2和vue3的區別&#xff1f;三、請說一說vue2和vue3響應式原理的區別&#xff1f;四、vue3 如何定義響應式數據?五、說一說你對vue3中的setup函數?六、說一說vue3中的路由…

【LLM06---相對位置編碼】

文章目錄 相對位置編碼經典式XLNET式T5式DeBERTa式 相對位置編碼 上一節我們介紹了絕對位置編碼&#xff0c;這一節我們來看相對位置編碼&#xff0c;也就是用相對位置信息來表示&#xff0c;之前每一個token的位置式通過一個絕對的位置向量來表示的&#xff0c;現在我們在計算…

純跟蹤算法本質解密:航向角偏差=預瞄角?數學證明與工程實踐

定義關鍵問題 在深入純跟蹤算法核心前&#xff0c;必須澄清一對容易被混淆但至關重要的概念&#xff1a; 概念坐標系物理意義計算方式航向角偏差(α_global)全局坐標系車輛航向與預瞄點方向的夾角預瞄點方位角 - 車輛航向角預瞄角(α_body)車身坐標系預瞄點相對于車輛縱軸的夾…

自動駕駛叉車在倉庫環境中是否安全?

隨著自動駕駛叉車的興起&#xff0c;倉庫運營持續演進。叉車自動化技術的引入使倉庫設施變得更快、更安全且更具成本效益。然而一個關鍵問題依然存在&#xff1a;它們在繁忙的倉庫環境中是否安全&#xff1f; 一 、什么是自動駕駛叉車&#xff1f; 自動駕駛叉車&#xff0c;也…

Neo4j操作指南:修改節點數據與新增節點屬性

Neo4j操作指南&#xff1a;修改節點數據與新增節點屬性 引言 Neo4j作為領先的圖數據庫&#xff0c;提供了靈活的數據操作方式。在實際應用中&#xff0c;我們經常需要修改已有節點的數據或為節點添加新屬性。本文將詳細介紹如何使用Cypher查詢語言在Neo4j中完成這些操作&…

AI大模型學習之基礎數學:微積分在AI大模型中的核心-梯度與優化(梯度下降)詳解

微積分在AI大模型中的核心:梯度與優化(梯度下降) 人工智能(AI)大模型的訓練和優化依賴于數學基礎,其中微積分、線性代數和概率統計構成了其理論核心。微積分在AI中的核心作用在于提供優化工具,尤其是通過梯度和梯度下降方法,幫助模型在高維參數空間中找到損失函數的最…

記錄tweenjs踩坑

初次上手tweenjs&#xff0c;試了很多示例代碼都不生效&#xff0c;結果在html中生效&#xff0c;在vue3的項目中怎么都不生效 <!DOCTYPE html> <html lang"en"><head><title>Tween.js / simplest possible example!</title><meta…

PINA開源程序用于高級建模的 Physics-Informed 神經網絡

?一、軟件介紹 文末提供程序和源碼下載 PINA 是一個開源 Python 庫&#xff0c;旨在簡化和加速科學機器學習 &#xff08;SciML&#xff09; 解決方案的開發。PINA 基于 PyTorch、PyTorch Lightning 和 PyTorch Geometry 構建&#xff0c;提供了一個直觀的框架&#xff0c;用…

一種對外IP/MAC地址收斂的軟硬件系統

----------原創不易&#xff0c;歡迎點贊收藏。廣交嵌入式開發的朋友&#xff0c;討論技術和產品------------- 今天發一篇五年前的文章&#xff0c;不調單板。對以太網和交換片的較多理解&#xff0c;對系統級的優化。 大部分的網絡設備&#xff0c;都由多種單板組成&#x…

【flink】 flink 讀取debezium-json數據獲取數據操作類型op/rowkind方法

flink 讀取debezium-json數據獲取數據操作類型op/rowkind方法。 op類型有c&#xff08;create&#xff09;,u&#xff08;update&#xff09;,d&#xff08;delete&#xff09; 參考官網案例&#xff1a;此處的"op": "u",就是操作類型。 {"before&qu…

某手游cocos2dlua反編譯

一、獲取加載的luac文件 通過frida hook libccos2dlua.so 的luaL_loadbuffer函數對luac進行dump js代碼如下&#xff0c;得到dump后的lua文件 // 要加載的目標庫名 var targetLibrary "libcocos2dlua.so"; var dlopen Module.findExportByName(null, "dlope…

`toRaw` 與 `markRaw`:Vue3 響應式系統的細粒度控制

&#x1f90d; 前端開發工程師、技術日更博主、已過CET6 &#x1f368; 阿珊和她的貓_CSDN博客專家、23年度博客之星前端領域TOP1 &#x1f560; 牛客高級專題作者、打造專欄《前端面試必備》 、《2024面試高頻手撕題》、《前端求職突破計劃》 &#x1f35a; 藍橋云課簽約作者、…