搭建turnserver
参考文件:
http://blog.csdn.net/kl222/article/details/20145423
为什么要搭建TURN服务器?
因为我们编写的sip客户端再和南瑞的sip服务器进行通信的时候,中间经过一个安全平台,这个安全平台具有NAT和防火墙功能。RTP和RTCP包传递不了。所以要增加一个TURN服务器。同时在sip客户端侧要实现TURN客户端功能。
搭建TURN服务器的步骤:
要安装两个软件 libConfuse和TURN server
1,下载
别人说通过svn和git方式下载,但是这个地址都下载不下来,提示地址错误。我是在windows下访问下面的两个网站,直接下载的文件。
官网:http://turnserver.sourceforge.net/
官网: http://www.nongnu.org/confuse/
下载的两个文件如下:
confuse-2.7.tar.gz
turnserver-0.7.3.tar.bz2
2,传输
我在windows下面使用的是xshell, 配置xshell下面的ZMODEM的上传和下载目录,就可以使用rz命令向CentOS主机传输文件了。
我是在根目录下创建了一个turnserver目录。
mkdir turnserver
3,解压
tar -xzvf confuse-2.7.tar.gz
tar -jxvf turnserver-0.7.3.tar.bz2
解压后的目录如下:

4,编译安装confuse-2.7
cd confuse-2.7 ./configure //这里不要指定目录,使用默认目录进行安装。默认是安装在/usr/local目录下面。 make sudo make install
没有报错,安装成功。
5,编译安装turnserver-0.7.3
cd turnserver-0.7.3 ./configure //这里不要指定目录,使用默认目录进行安装。默认是安装在/usr/local目录下面。 make sudo make install
这两个只所以没有指定安装目录是因为设置了安装目录后,再安装turnserver的时候,提示前面的confuse没有安装。
6,熟悉、建立、修改配置文件。
6.1 在turnserver源码根目录下的extra目录下有配置模板可以参考。
turnserver.fedora.initd #fedora平台的启动脚本
turnserver.spec #fedora平台的启动脚本
turnserver.debian.initd #debian平台的启动脚本
turnserver.conf.template#配置文件
turnusers.txt.template #用户名、密码配置文件
6.2 建立配置文件:
[hy@localhost-turnserver]$ cd extra/
[hy@localhost-extra]$ cp turnserver.conf.template /usr/local/etc/turnserver.conf
[hy@localhost-extra]$ cp turnusers.txt.template /usr/local/etc/turnusers.txt
[hy@localhost-extra]$ cd /usr/local/etc
6.3修改配置文件
cd /usr/local/etc
chmod 777 turnserver.conf
chmod 777 turnusers.txt
vi turnserver.conf
listen_address = {"183.62.225.76" } #把对应公网网卡的IP地址写入(如果公网地址是用镜像的,则用镜像的那个IP地址),一般只要改这个配置,其它的用默认值就可以了。
## Account method.
account_method = "file" #配置账户数据为文件
## Account file (if account_method = file).
account_file ="/usr/local/etc/turnusers.txt" #指定账户文件位置
[root@rlnf-76etc]# vi turnusers.txt
foo:bar:domain.org:authorized
用户名:密码:领域:需要验证的
领域的值应与配置文件(turnserver.conf)中的
## Realm value.
realm = "domain.org"
的值相同.这个值用于密码确认的.
7,启动turnserver
[root@rlnf-76etc]# cd ../sbin
[root@rlnf-76sbin]# ./turnserver -c /usr/local/etc/turnserver.conf
8 启动回显服务:
在服务器上启动回显测试服务端程序:
[root@rlnf-76bin]# ./test_echo_server
UDP Echo server started on port 4588
9 测试服务器是否正常
在其它机器上(客户机器)启动测试程序:
rdc@rdc-Virtual-Machine:/home/turnserver/src$./test_turn_client -t udp -s 183.62.225.76 -p 183.62.225.76 -w 4588 -u foo -g 1234-d domain.org
Protocol: udp (17) use TLS: 0.
sock: 3 speer: (nil) connected!
Send Allocate request.
Send Allocate request.
Probably wrong credentials or requestedfamily not supported.
这个是说权限错误,一般是用户或密码不对。修改用户和密码,再次运行:
rdc@rdc-Virtual-Machine:/home/turnserver/src$./test_turn_client -t udp -s 183.62.225.76 -p 183.62.225.76 -w 4588 -u foo -gbar -d domain.org
Protocol: udp (17) use TLS: 0.
sock: 3 speer: (nil) connected!
Send Allocate request.
Send Allocate request.
Allocate an address!
Send CreatePermission request.
Permission installed!
Send Send indication.
Receive data: 1024
Send CreatePermission request.
Channel bound to 16393.
Send ChannelData.
Received ChannelData: 1024 bytes
Send Refresh request.
Cleanup and exit.
10 服务端打印的日志:
::26.632297 [turnserver_main:] Received UDP on listening address ::26.632336[turnserver_listen_recv:] Nomessage integrity ::26.636506 [turnserver_main:] Received UDP on listening address ::26.636534[turnserver_listen_recv:] OK basicvalidation are done, process the TURN message ::26.636546 [turnserver_process_turn:] Process a TURN message ::26.636559[turnserver_process_allocate_request:] Allocate request received! ::26.636573[turnserver_process_allocate_request:] lifetime: seconds ::26.636667 [turnserver_process_allocate_request:] Account foo, allocations used: ::26.636719[turnserver_process_allocate_request:] Allocation successful, send success allocate response ::26.640733 [turnserver_main:] Received UDP on listening address ::26.640758[turnserver_listen_recv:] OK basicvalidation are done, process the TURN message ::26.640770[turnserver_process_turn:] Process aTURN message ::26.640781[turnserver_process_createpermission_request:] CreatePermission request received ::26.640807[turnserver_process_createpermission_request:] Install permission for 183.62.225.76 ::26.640828[turnserver_process_createpermission_request:] CreatePermission successful, send successCreatePermission response ::26.645088 [turnserver_main:] Received UDP on listening address ::26.645110[turnserver_listen_recv:] OK basicvalidation are done, process the TURN message ::26.645121[turnserver_process_turn:] Process aTURN message ::26.645131[turnserver_process_send_indication:] Send indication received! ::26.645143[turnserver_check_bandwidth_limit:] Tokendown bucket available: , tokens requested: ::26.645154[turnserver_process_send_indication:] Will not set DF flag ::26.645166[turnserver_process_send_indication:] Send data to peer ::26.645224 [turnserver_main:] Received UDP on a relayed address ::26.645241[turnserver_check_bandwidth_limit:] Tokenup bucket available: , tokens requested: ::26.645314[turnserver_relayed_recv:] Send datato client ::26.649140 [turnserver_main:] Received UDP on listening address ::26.649165[turnserver_listen_recv:] OK basicvalidation are done, process the TURN message ::26.649177[turnserver_process_turn:] Process aTURN message ::26.649187[turnserver_process_channelbind_request:] ChannelBind request received! ::26.649199[turnserver_process_channelbind_request:] Client request a ChannelBinding for 183.62.225.76 ::26.649234[turnserver_process_channelbind_request:] ChannelBind successful, send success ChannelBind response ::26.653515 [turnserver_main:] Received UDP on listening address ::26.653532[turnserver_process_channeldata:] ChannelData received! ::26.653544[turnserver_check_bandwidth_limit:] Tokendown bucket available: , tokens requested: ::26.653557[turnserver_process_channeldata:] Send ChannelData to peer ::26.653596 [turnserver_main:] Received UDP on a relayed address ::26.653611[turnserver_check_bandwidth_limit:] Tokenup bucket available: , tokens requested: ::26.653623[turnserver_relayed_recv:] Send datato client ::26.657563 [turnserver_main:] Received UDP on listening address ::26.657586[turnserver_listen_recv:] OK basicvalidation are done, process the TURN message ::26.657598[turnserver_process_turn:] Process aTURN message ::26.657608[turnserver_process_refresh_request:] Refresh request received! ::26.657618[turnserver_process_refresh_request:] lifetime: seconds ::26.657664[turnserver_process_refresh_request:] Account foo, allocations used: ::26.657677[turnserver_process_refresh_request:] Explicit delete of allocation ::26.657692[turnserver_process_refresh_request:] Refresh successful, send success refresh response
服务端打印的日志
搭建turnserver的更多相关文章
- 在ubuntu上搭建turnserver
这边文章的目的:搭建turnserver,设定开机启动 1.下载turnserver的源码,最新的地址https://code.google.com/p/rfc5766-turn-server/ no ...
- 搭建自己的AppRTCDemo服务器
http://www.jianshu.com/p/c55ecf5a3fcf http://io.diveinedu.com/2015/02/05/%E7%AC%AC%E5%85%AD%E7%AB%A0 ...
- google开源服务器apprtc的搭建
本文参考网帖: http://www.jianshu.com/p/c55ecf5a3fcf http://io.diveinedu.com/2015/02/05/%E7%AC%AC%E5%85%AD% ...
- WebRTC服务器——Licode 环境搭建
WebRTC服务器--Licode 环境搭建 系统配置 阿里云服务器 Ubuntu 14.04.5 LTS Docker 环境搭建 在一台空的机器上搭建docker环境,先要安装docker,执行下面 ...
- WebRTC信令控制简介与STUN, TURN服务器搭建
本文将向大家介绍两个方面的知识: WebRTC信令控制 STUN/TURN服务器的搭建 在前面的文章中已经向大家介绍了如何构建信令服务器.但构建的信令服务器是如何工作的?哪些消息需要信令服务器控制和中 ...
- stun服务器搭建(coTurn)
0. 前言 好久之前写过一篇搭建WebRTC的文章,里面有简单的说到怎么搭建一个stun服务.但那时只是一笔带过.正好,这两天搭建stun服务,这篇博客就再复习一遍,并把搭建过程整理一下. 1. 安装 ...
- p2p webrtc服务器搭建系列1: 房间,信令,coturn打洞服务器
中继(relay) 在RTCPeeConnection中,使用ICE框架来保证RTCPeerConnection能实现NAT穿越 ICE,全名叫交互式连接建立(Interactive Connecti ...
- webrtc笔记(1): 基于coturn项目的stun/turn服务器搭建
webrtc是google推出的基于浏览器的实时语音-视频通讯架构.其典型的应用场景为:浏览器之间端到端(p2p)实时视频对话,但由于网络环境的复杂性(比如:路由器/交换机/防火墙等),浏览器与浏览器 ...
- WebRTC 入门教程(二)| WebRTC信令控制与STUN/TURN服务器搭建
WebRTC 入门教程(二)| WebRTC信令控制与STUN/TURN服务器搭建 四月 4, 2019 作者:李超,音视频技术专家.本文首发于 RTC 开发者社区,欢迎在社区留言与作者交流. htt ...
随机推荐
- 失败的数据库迁移UDB
公司采用的是ucloud的云主机,数据库也是架设在云主机上.由于数据越来越多数据查询数据越来越慢,所以我决定往 UDB上迁移.当时考虑的理由如下: (1)云主机底层架设在虚拟机上IO性能有折损,而UD ...
- arm-elf-gcc汇编代码个人理解
arm-elf-gcc汇编代码个人理解 有关arm-elf-gcc的安装使用问题请参照本人博客的另一篇文章http://www.cnblogs.com/wsine/p/4664503.html 由于各 ...
- Linux C 文件与目录2 文件的打开与关闭
文件的打开与关闭 open和close 文件的打开指的是从磁盘中找到一个文件,返回一个整形的打开文件顺序的编号.打开的文件处于可读.可写状态.文件的关闭指的是释放打开的文件,是文件处于不可读写的状态. ...
- 卷积神经网络CNN介绍:结构框架,源码理解【转】
1. 卷积神经网络结构 卷积神经网络是一个多层的神经网络,每层都是一个变换(映射),常用卷积convention变换和pooling池化变换,每种变换都是对输入数据的一种处理,是输入特征的另一种特征表 ...
- ArrayList、LinkedList、Vector的区别
Arraylist和Vector是采用数组方式存储数据,此数组元素数大于实际存储的数据以便增加插入元素,都允许直接序号索引元素,但是插入数据要涉及到数组元素移动等内存操作,所以插入数据慢,查找有下标, ...
- 前端之JavaScript第三天学习(8)-JavaScript-对象
JavaScript 中的所有事物都是对象:字符串.数字.数组.日期,等等. 在 JavaScript 中,对象是拥有属性和方法的数据. 属性和方法 属性是与对象相关的值. 方法是能够在对象上执行的动 ...
- 04.spring-data-redis与Jedis整合使用
1.spring-data-redis与Jedis简单整合 spring-data-redis与Jedis简单整合,Redis没有任何集群只是单节点工作,使用连接池 1.创建spring-contex ...
- 【BZOJ】【4003】【JLOI2015】城池攻占
可并堆 QAQ改了一下午……最终弃疗求助zyf……居然被秒了QAQ真是弱到不行(zyf太神了Orz) 还是先考虑部分分的做法: 1.$n,m\leq 3000$:可以暴力模拟每个骑士的攻打过程,也可以 ...
- spring AspectJ的Execution表达式说明
Aspectj切入点语法定义 在使用spring框架配置AOP的时候,不管是通过XML配置文件还是注解的方式都需要定义pointcut"切入点" 例如定义切入点表达式 execut ...
- On Explainability of Deep Neural Networks
On Explainability of Deep Neural Networks « Learning F# Functional Data Structures and Algorithms is ...