概要
在 WebRTC 网络传输模块中,当遇到 NAT 之间无法打通的情况下,会使用 TURN 协议通过中转的方式实现端与端之间的通信。Coturn 就是一种开源的 STUN/TURN 服务器,它可以让你轻松地搭建一个能够在 NAT 防火墙和代理服务器背后运行的实时通信系统。Coturn 支持各种协议和技术,包括 STUN(Session Traversal Utilities for NAT)、TURN(Traversal Using Relays around NAT)和 ICE(Interactive Connectivity Establishment)。Coturn 可以用于向 WebRTC 应用程序提供 TURN 服务器,这些应用程序需要在 P2P 通信中转储流量。本文主要介绍 Coturn 在 Linux、Windows 系统下部署的步骤。

Linux 系统下部署(以 CentOS8.0 为例)
下载 libevent2,因为 Coturn 编译的时候会用到 libevent2。

wget https://github.com/libevent/libevent/releases/download/release-2.1.10-stable/libevent-2.1.10-stable.tar.gz

解压 libevent-2.1.10-stable.tar.gz

tar -zxvf libevent-2.1.10-stable.tar.gz

编译并安装 libevent2

cd libevent-2.1.10-stable
./configure && make && make install

通过 wget 命令下载 Coturn 安装包(新版本可能会产生未知的编译问题,所以这里下载的是 4.5.1.1 老版本)。

wget https://github.com/coturn/coturn/archive/4.5.1.1.tar.gz

使用 tar -zxvf 命令解压 4.5.1.1.tar.gz

tar -zxvf 4.5.1.1.tar.gz

编译并安装 Coturn

cd coturn-4.5.1.1
./configure --prefix=/usr/local/coturn
make && make install

配置 Coturn
切换到 coturn 的 etc 目录,拷贝一份 turnserver.conf.default 再进行修改。

cd /usr/local/coturn/etc
cp ./turnserver.conf.default ./turnserver.conf
vi ./turnserver.conf

修改 turnserver.conf 文件配置内容,realm 需要指定 IP 或域名,否则无法在 WebRTC 本地库中使用,虽然使用 trickle-ice 可以正常访问,但是在 WebRTC 本地库中是没法正常使用的。

// 指定侦听的端口。
listening-port=3478
// 云主机内网 IP 地址。
listening-ip=xxx.xxx.xxx.xxx
// 云主机的公网 IP 地址。
external-ip=xxx.xxx.xxx.xxx
// 这个很重要,如果没有配置这个就服务使用中转服务。
// 云主机的公网 IP 地址或域名。
realm=xxx.xxx.xxx.xxx
// 访问 STUN/TURN 服务的用户名和密码。
user=admin:123456

云主机端口配置
如果是阿里云、腾讯云的云主机,需要到控制中的安全策略组或者防火墙中允许 3478、49152-65535 端口 UDP/TCP 通行。

启动 Coturn
添加环境变量

vi ~/.bashrc
export PATH=$PATH:/usr/local/coturn/bin
source ~/.bashrc

通过配置文件启动

turnserver -c /usr/local/coturn/etc/turnserver.conf

测试 STUN/TURN 服务,使用火狐浏览器(其他浏览器有问题)打开以下连接
Trickle ICE 出现 relay 说明配置成功。
![在这里插入图片描述](https://img-blog.csdnimg.cn/12dfa5211bf1410ead8d11e1fc2319ae.png
在这里插入图片描述
在这里插入图片描述
将 Coturn 设置为系统服务
把 Coturn 设置成系统服务,便于开机自动启动,就不用手动启动了。

执行以下命令:

touch /usr/lib/systemd/system/coturn.service

然后编辑 coturn.service 文件

vi coturn.service

设置 coturn.service 文件内容

[Unit]
Description=Coturn Server
After=network.target
 
[Install]
WantedBy=multi-user.target
 
[Service]
User=root
Group=root
ExecStart=/usr/local/coturn/bin/turnserver -c /usr/local/coturn/etc/turnserver.conf
LimitNOFILE = 5000

将 coturn 设置开机启动

systemctl enable coturn

启动 coturn 服务在这里插入代码片

systemctl start coturn
Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐