Ubuntu中搭建ICE服务器(Coturn)

Ubuntu中搭建ICE服务器(Coturn)1.WebRTC的P2P穿透WebRTC的P2P穿透部分是由libjingle实现的.步骤顺序大概是这样的:尝试直连.通过STUN服务器进行穿透无法穿透则通过TURN服务器中转STUN服务器比较简单.网上也有很多公开的STUN服务器可以用于测试,例如:stun.ideasip.com在WebRTC的P2P应用中,使用公开的STUN服务器时,有时响应比较慢,这就需要自己搭一个…

大家好,又见面了,我是你们的朋友全栈君。

1. WebRTC的P2P穿透

WebRTC的P2P穿透部分是由libjingle实现的.

步骤顺序大概是这样的:

  1. 尝试直连.
  2. 通过STUN服务器进行穿透
  3. 无法穿透则通过TURN服务器中转

STUN服务器比较简单. 网上也有很多公开的STUN服务器可以用于测试,例如: stun.ideasip.com

在WebRTC的P2P应用中,使用公开的STUN服务器时,有时响应比较慢,这就需要自己搭一个ICE服务器即可。ICE服务器包含STUN和TURN两部分,实际上只需要TURN服务器就可以解决P2P的穿透问题。

Coturn是在原来的TurnServer上增加了一些高级特性. (这是作者的描述, 两个项目是同一个作者. 作者更推荐使用Coturn).

  • coturn 支持tcp, udp, tls, dtls 连接.
  • coturn 支持linux bsd solaris mac os. 暂不支持windows (未来会支持)

2. 安装Coturn

2.1 安装依赖组件

使用下面相关命令安装Coturn依赖的相关库文件

sudo apt-get install libssl-dev
sudo apt-get install libevent-dev
sudo apt-get install libpq-dev
sudo apt-get install mysql-client
sudo apt-get install libmysqlclient-dev
sudo apt-get install libhiredis-dev
sudo apt-get install git

2.2 下载编译安装Coturn

相关命令如下

git clone https://github.com/coturn/coturn
cd coturn
./configure
make
sudo make install

2.3 验证Coturn安装

使用下面命令查看Coturn的安装情况

which turnserver

如下图所示,可以看到Coturn的turnserver所在的路径,表示安装成功
在这里插入图片描述

3. 配置Coturn

3.1 创建配置文件

从默认的配置文件中复制生成Coturn的配置文件 turnserver.conf

sudo cp /usr/local/etc/turnserver.conf.default /usr/local/etc/turnserver.conf

3.2 生成SSL证书

生成服务器使用的SSL证书,相关命令如下所示:

sudo openssl req -x509 -newkey rsa:2048 -keyout /etc/turn_server_pkey.pem -out /etc/turn_server_cert.pem -days 99999 -nodes

命令相关输入信息可根据需要填写,如下图所示
在这里插入图片描述

可以在 /etc 目录下找到生成的两个证书文件,如下图所示
在这里插入图片描述

3.3 简单使用

至此,就可以直接运行下面的命令进行简单的使用了

turnserver -o -a -f -v --mobility -m 10 --max-bps=100000 --min-port=32355 --max-port=65535 --user=keda:keda1234 --user=keda2:keda1234 -r keda

其中:

  • -m 10 表示启动十个relay线程
  • –max-bps=100000 限制最大速度为100KB/s
  • 当TURN Server用于WebRTC时,必须使用long-term credential mechanism, 即指定 -a 或者 –lt-cred-mech
  • 添加了两个用户:keda和keda2,以及对应的密码

3.4 自定义设置

3.4.1 生成用户Key信息

从安全性方面考虑,可以为账户生成key, 这样就可以直接通过key登录,而不需要提供密码。

key 通过turnadmin生成, 需要(username, password, realm),realm是启动turn server时-r 参数指定的。生成用户Key信息,命令格式如下:

turnadmin -k –u 用户名 -p 密码 -r 域名

例如,用户名=keda、密码=keda1234、域名=keda,则命令如下:

turnadmin -k –u keda -p keda1234 -r keda

生成的Key信息如下图所示
在这里插入图片描述

3.4.2 创建用户配置文件

创建用户配置文件turnuserdb.conf,命令如下:

sudo vi /etc/turnuserdb.conf

在其中填入之前生成的用户名和key
在这里插入图片描述

3.4.3 修改配置文件

首先,使用 ifconfig 命令查看一下服务器的网卡类型:
在这里插入图片描述

其次,修改Coturn的配置文件,相关命令如下所示:

vi /usr/local/etc/turnserver.conf

配置文件的内容,如下所示:

listening-device=填写自己的网卡类型
relay-device=填写自己的网卡类型
listening-ip=ip地址
listening-port=3478
tls-listening-port=5349
relay-ip=ip地址
external-ip=ip地址
relay-threads=50
lt-cred-mech
static-auth-secret=用户名
user=用户名:密钥
userdb=/etc/turnuserdb.conf
#max-bps=102400
pidfile="/var/run/turnserver.pid"
no-loopback-peers
no-multicast-peers
sha256
mobility
no-cli
cert=/etc/turn_server_cert.pem
pkey=/etc/turn_server_pkey.pem
stale-nonce
use-auth-secret
Verbose
fingerprint

如下图所示,是虚拟机上的配置:
在这里插入图片描述

3.4.4 运行turnserver

使用下面命令运行turnserver就可以进行使用了

sudo turnserver -L 192.168.186.141 -o -a -b /etc/turnuserdb.conf -f -r keda

4. 运行并验证

4.1 查看Turnserver的运行情况

在这里插入图片描述

4.2 验证Turnserver的P2P穿透情况

使用 turnutils_uclient 工具验证Turnserver的P2P穿透情况,相关命令如下:

turnutils_uclient -u keda -w keda1234 192.168.186.141

执行结果,如下图所示
在这里插入图片描述

5. 参考资料

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130416.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月14日 下午12:00
下一篇 2022年6月14日 下午12:00


相关推荐

  • csgo新出的开箱网站_csgo网站开箱推荐

    csgo新出的开箱网站_csgo网站开箱推荐2021csgo开箱网站有哪些?2021最新收集的CSGO国内网页开箱子网站大全!##以下国内知名CSGO开箱网站大全官网直达链接优惠码/推广码网站状态incsgocsgogo直接取回skinsdogcsgogo直接取回npskinscsgogo直接取回fateskinscsgo直接取回box818csgo直接取回piggycasecsgogo可取回yskins暂无可取回88steamcsgo可取回c

    2022年10月5日
    4
  • mysql连接数据库命令_linux进入mysql的命令

    mysql连接数据库命令_linux进入mysql的命令一、MySQL连接本地数据库,用户名为“root”,密码“123”(注意:“-p”和“123”之间不能有空格)C:>mysql-hlocalhost-uroot-p123二、MySQL连接远程数据库(192.168.0.201),端口“3306”,用户名为“root”,密码“123”C:>mysql-h172.16.16.45-P3306-uroot-p123三、MySQL连接本地数据库,用户名为“root”,隐藏密码C:>mysql-hloc

    2025年11月25日
    4
  • 实战模拟│揭秘为啥年会你抽不到特等奖[通俗易懂]

    实战模拟│揭秘为啥年会你抽不到特等奖[通俗易懂]抽奖不只是概率性事件,有可能是确定性事件

    2022年8月16日
    13
  • 免费HTTP代理商如何

    免费HTTP代理商如何现在是信息化时代 许多互联网技术情景例如网络爬虫数据采集 电子商务实际效果导量 网上推广这些 都离不了 HTTP 代理商 IP 而很多人第一个想起的是免费 HTTP 代理商 什么叫服务器代理 代理服务器是处于电脑浏览器和 Web 服务端中间的一台网络服务器 如果你根据服务器代理网上访问时 电脑浏览器没有立即到 Web 服务端去取回来网页页面 反而是向服务器代理发出请求 由代理服务器来取回来电脑浏览器所必须的信息内容 并传递让你的电脑浏览器 尽管在互联网上可以免费获取一些代理商 IP 可是不要钱的自始至终不具有健全的

    2026年3月20日
    2
  • Java封装动态编译

    Java封装动态编译java 实现字符串的动态编译

    2026年3月18日
    2
  • 南大lamda实验室失败面经分享「建议收藏」

    南大lamda实验室失败面经分享「建议收藏」2019年保研基本上尘埃落定,博主最后去了北大信科读研。关于北大的夏令营,把北大往年的夏令营真题刷一刷https://blog.csdn.net/caozixuan98724/article/details/93521208,面试就个凭造化了。值得说的内容不多,反而是最早开始的南大一行,值得说的地方很多,非常有趣,作为我参加的第一个保研面试,跪的一塌糊涂。初审首先先讲lamda实验室的初审…

    2022年4月29日
    99

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号