测试TURN服务器的简单方法

i s*_*ing 3 amazon-ec2 amazon-web-services webrtc turn

我正在看这个站点,该站点应该是测试TURN服务器的表(根据此答案)。

plugin.temasys.com.sg/demo/samples/web/content/peerconnection/trickle-ice/index.html

我输入了服务器信息,但找不到任何可确定服务器是否正常工作的信息。即使没有选择服务器,“候选冰”部分也看起来相同。

我的TURN服务器安装在Amazon EC2上。我遵循了coturn存储库中的安装说明:

github.com/coturn/coturn/blob/master/INSTALL

以下是执行命令从此处启动TURN服务器时在服务器中获得的内容:

RFC 3489/5389/5766/5780/6062/6156 STUN/TURN Server
Version Coturn-4.2.1.2 'Monza'
0:
Max number of open files/sockets allowed for this process: 4096
0:
Due to the open files/sockets limitation,
max supported number of TURN Sessions possible is: 2000 (approximately)
0:

==== Show him the instruments, Practical Frost: ====

0: TLS supported
0: DTLS supported
0: AEAD supported
0: Redis supported
0: PostgreSQL supported
0: MySQL supported
0: MongoDB is not supported
0: OpenSSL compile-time version 0x1000106f: fresh enough
0: Default Net Engine version: 3 (UDP thread per CPU core)

=====================================================

0: Config file found: /usr/local/etc/turnserver.conf
0: Listener address to use: 172.31.43.176
0: Relay address to use: 172.31.43.176
0: Config file found: /usr/local/etc/turnserver.conf
0: Domain name:
0: Default realm: realm
0: Config file found: /usr/local/etc/turnuserdb.conf
0: WARNING: cannot find certificate file: turn_server_cert.pem (1)
0: WARNING: cannot start TLS and DTLS listeners because certificate file is not set properly
0: WARNING: cannot find private key file: turn_server_pkey.pem (1)
0: WARNING: cannot start TLS and DTLS listeners because private key file is not set properly
0: pid file created: /var/run/turnserver.pid
0: IO method (main listener thread): epoll (with changelist)
0: WARNING: I cannot support STUN CHANGE_REQUEST functionality because only one IP address is provided
0: Wait for relay ports initialization...
0:   relay 172.31.43.176 initialization...
0:   relay 172.31.43.176 initialization done
0: Relay ports initialization done
0: IO method (general relay thread): epoll (with changelist)
0: IPv4. UDP listener opened on: 172.31.43.176:3478
0: Total UDP servers: 0
0: Total General servers: 1
0: turn server id=0 created
0: IPv4. TCP listener opened on : 172.31.43.176:3478
0: IO method (cli thread): epoll (with changelist)
0: IPv4. CLI listener opened on : 127.0.0.1:5766
0: IO method (auth thread): epoll (with changelist)
Run Code Online (Sandbox Code Playgroud)

它似乎正在工作,但是我怎么知道?我为自己的无知表示歉意,我已经阅读了很多有关此内容的文档,无法跟踪所有内容。

编辑:好了,正在发生:)

每当使用上述网站时,我现在都在轮到服务器上收到这些信息:

64: ERROR: check_stun_auth: Cannot find credentials of user <ubuntu>
64: session 000000000000000004: realm <realm> user <ubuntu>: incoming packet message processed, error 401: Unauthorised
Run Code Online (Sandbox Code Playgroud)

编辑2:我删除了ubuntu部分,现在正在收到似乎是成功的响应。仍然还不十分清楚这意味着什么,但这只是一个开始:)

274: handle_udp_packet: New UDP endpoint: local addr 172.31.43.176:3478, remote addr 12.123.123.123:64064
274: session 000000000000000007: realm <realm> user <>: incoming packet BINDING processed, success
274: handle_udp_packet: New UDP endpoint: local addr 172.31.43.176:3478, remote addr 12.123.123.123:64068
274: session 000000000000000008: realm <realm> user <>: incoming packet BINDING processed, success
274: session 000000000000000007: realm <realm> user <>: incoming packet message processed, error 401: Unauthorised
274: session 000000000000000008: realm <realm> user <>: incoming packet message processed, error 401: Unauthorised
274: IPv4. Local relay addr: 172.31.43.176:56767
274: session 000000000000000007: new, realm=<realm>, username=<turnadm>, lifetime=600
274: session 000000000000000007: realm <realm> user <turnadm>: incoming packet ALLOCATE processed, success
274: IPv4. Local relay addr: 172.31.43.176:54363
274: session 000000000000000008: new, realm=<realm>, username=<turnadm>, lifetime=600
274: session 000000000000000008: realm <realm> user <turnadm>: incoming packet ALLOCATE processed, success
274: session 000000000000000007: realm <realm> user <turnadm>: incoming packet ALLOCATE processed, success
274: session 000000000000000008: realm <realm> user <turnadm>: incoming packet ALLOCATE processed, success
Run Code Online (Sandbox Code Playgroud)

小智 9

如果您有使用WebRTC的测试应用程序。

您可以在Firefox上强制启用TURN。

标签: about:config

搜索: media.peerconnection.ice.relay_only

设置为 true

目前,Firefox仅使用TURN中继。

  • 有没有办法在chrome浏览器中做同样的事情? (2认同)

mid*_*ido 7

编辑: github.io 中的一个很好的实现从评论到另一个答案(在 IceTransports 值中选择“中继”):

Test TURN Server


在您的浏览器控制台(firefox 或 chrome)中运行以下代码,替换127.0.0.1为您的 aws 的外部 IP,这应该会给您答案:

function checkTURNServer(turnConfig, timeout){ 

  return new Promise(function(resolve, reject){

    setTimeout(function(){
        if(promiseResolved) return;
        resolve(false);
        promiseResolved = true;
    }, timeout || 5000);

    var promiseResolved = false
      , myPeerConnection = window.RTCPeerConnection || window.mozRTCPeerConnection || window.webkitRTCPeerConnection   //compatibility for firefox and chrome
      , pc = new myPeerConnection({iceServers:[turnConfig]})
      , noop = function(){};
    pc.createDataChannel("");    //create a bogus data channel
    pc.createOffer(function(sdp){
      if(sdp.sdp.indexOf('typ relay') > -1){ // sometimes sdp contains the ice candidates...
        promiseResolved = true;
        resolve(true);
      }
      pc.setLocalDescription(sdp, noop, noop);
    }, noop);    // create offer and set local description
    pc.onicecandidate = function(ice){  //listen for candidate events
      if(promiseResolved || !ice || !ice.candidate || !ice.candidate.candidate || !(ice.candidate.candidate.indexOf('typ relay')>-1))  return;
      promiseResolved = true;
      resolve(true);
    };
  });   
}

checkTURNServer({
    url: 'turn:127.0.0.1',
    username: 'test',
    credential: 'test'
}).then(function(bool){
    console.log('is my TURN server active? ', bool? 'yes':'no');
}).catch(console.error.bind(console));
Run Code Online (Sandbox Code Playgroud)

PS:确保两件事,在启动 TURN 服务器时将 aws 的外部 ip 作为参数的一部分传递,确保您使用的端口在 aws 设置中打开用于接收和发送。

  • @mding5692,请参阅下面成功测试的输出。`时间组件类型基础协议地址端口优先级 0.010 1 host 0 udp addr.local 59895 126 | 32512 | 32512 255 0.025 1 主机 4 tcp 地址.local 9 125 | 32704 | 32704 255 0.026 2 主机 0 udp 地址.local 59896 126 | 32512 | 32512 254 0.027 2 主机 4 tcp 地址.local 9 125 | 32704 | 32704 254 11.207 完成` (2认同)