• STUN, TURN, ICE介绍


    STUN

    STUN协议为终端提供一种方式能够获知自己经过NAT映射后的地址,从而替代位于应用层中的私网地址,达到NAT穿透的目的。STUN协议是典型的Client-Server协议,各种具体应用通过嵌入STUN客户端与STUN Server端通讯来完成交互。 

    在典型的运用STUN进NAT穿透的场景中STUN客户端首先向位于公网上的STUN务器 发送Binding Request消息,STUN服务器接收到请求消息后识别出经过NAT转换后的公网地址60.1.1.1:12345,将其附加在Binding Response消息中返回给客户端。客户端得到这个地址 后用它替换SDP中的私网地址与终端B完成媒体协商。使用STUN进行NAT穿透对应用的要 求是必须使用同样的端口与STUN服务器交互和进行应用层通讯,比如当希望使用端口 37000进行RTP包的NAT穿透时,必须同样使用37000端口与STUN服务器通讯,否则从STUN 服务器获得的NAT映射后的地址一般与实际地址时不一样的。另一个要求是STUN客户端与 服务器端的通讯和应用使用获得的NAT映射地址进行应用层通讯在时间上必须有连贯性, 这源于NAT设备建立的绑定有生存时间,当原绑定消亡后,NAT设备为同一个私网地址建 立的新绑定往往不同,因此转换后的公网地址是不同的。

     

    STUN方案的特性如下表:

     

    特性

    说明

    实现复杂度

    实现简单

    TCP穿透支持

    不支持

    对现有设备的要求

    要求客户端支持,对现有NAT备无改动要求,需增加STUN服务器

    可扩展性

    可扩展性好,与具体协议无关

    安全性

    一般

    健壮性

    差,不支持symmentricNAT

    其他

    支持自动检测NAT,使用户即使在使用STUN协议无法实现NAT

    穿透时还可以根据NAT类型自主选择其他可使用的NAT穿透方案

     

    TURN

    TURN解决NAT穿透的思路与STUN类似,都是通过修改应用层中的私网地址达到NAT穿透。 与STUN不同的是,TURN是通过两方通讯的“中间人”的方式实现穿透,在这种方式下, 要进行通讯的两方分别与位于公网上的TURN服务器建立各自的连接进行通讯,由服务器负 责在两方之间进行数据转发。要达到这个目的,实现TURN客户端的终端必须在通讯开始前 与TURN服务器进行交互,得到服务器为其临时分配的位于TURN服务器上的公网地址,客户端使用它替换位于应用层中的私网地址。

    TURN方案的特性如下表:

     

    特性

    说明

    实现复杂度

    难于实现。TURN的安全性设计增加终端设置的复杂度

    TCP穿透支持

    支持

    对现有设备的要求

    对现有NAT设备无要求,要求客户端支持,需增加TURN服务器s

    可扩展性

    可扩展性好,与具体协议无关

    安全性

    一般

    健壮性

    好,支持所有类型的NAT

    其他

    P2P穿透方式相比,性能时relay穿透方式的弱点。另外TURN无法

    实现负载分担,解决的方式是media relay服务器的分配工作放在 SIP proxy完成

    ICE

    与STUN和TURN相比,ICE并非是解决NAT穿透问题的协议,而是一个框架,在这个框架中, 可以整合其他现存的NAT穿透协议,如STUN、TURN、RSIP等。区别于其他的NAT穿透解 决方案,ICE是一种探索和更新式的解决方案,通过搜集自身和对端尽可能多的网络信息(各种网络地址),尝试在这些地址间建立数据通道,并在这一过程中不断更新先前收集到的信息,从而找出和选择能够进行NAT穿透的数据通道。

    ICE方案的特性如下表:

    特性

    说明

    实现复杂度

    一般

    TCP穿透支持

    支持

    对现有设备的要求

    NAT备无要求,支持所有类型的NAT备。客户端必须支持,

    网路结构中需增加STUN/TURN服务器

    可扩展性

    可扩展性好,与具体协议无关

    安全性

    较好

    健壮性

    好,适用与所有NAT及NAT拓扑类型,且由于存在中继服务器,NAT

    穿透一般总是能成功

    其他

     

     

    http://www.voip-info.org/wiki/view/ICE

    http://www.voip-info.org/wiki/view/TURN

    http://www.voip-info.org/wiki/view/STUN-bis

    试验UDP打洞穿透NAT

    http://www.hankcs.com/program/network/test-udp-holes-penetrating-nat.html#comments

  • 相关阅读:
    springboot对JPA的支持
    Hibernate-什么是orm思想
    利用Struts拦截器完成文件上传功能
    Struts2的CRUD
    struts2的初步认识
    Maven搭建
    java虚拟机
    Map集合
    Set集合(TreeSet)
    Set集合的
  • 原文地址:https://www.cnblogs.com/cnhk19/p/9460041.html
Copyright © 2020-2023  润新知