首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

webRTC搭建:STUN 和 TURN 服务器 链接google的有点慢,是不是可以自己搭建

  • 25-03-07 21:22
  • 4312
  • 9083
blog.csdn.net

如果使用 Google 提供的 STUN/TURN 服务器速度较慢,你完全可以自己搭建 STUN 和 TURN 服务器。这有助于提升网络连接速度和稳定性,特别是在需要穿透 NAT 或防火墙的网络环境下。

下面是如何自己搭建 STUN 和 TURN 服务器的具体步骤:

1. 选择 TURN/STUN 服务器软件

推荐使用 Coturn,这是一个开源且功能强大的 STUN 和 TURN 服务器。Coturn 支持完整的 STUN、TURN 和 Relay 功能,适用于 WebRTC 应用。

2. 安装 Coturn

在 Ubuntu/Debian 上安装

打开终端,使用以下命令安装 Coturn:

sudo apt update
sudo apt install coturn
  • 1
  • 2
在 CentOS 上安装

使用以下命令安装 Coturn:

sudo yum install epel-release
sudo yum install coturn
  • 1
  • 2

3. 配置 Coturn 服务器

安装完成后,需要配置 Coturn。配置文件通常位于 /etc/turnserver.conf 或 /etc/coturn/turnserver.conf。

编辑配置文件

使用文本编辑器编辑配置文件:

sudo nano /etc/turnserver.conf
  • 1
配置文件示例

你可以根据自己的需求配置 Coturn,以下是一个基本的配置示例:

# 监听的端口,默认是 3478
listening-port=3478

# 如果需要启用 TLS,请启用 5349 端口
# tls-listening-port=5349

# 服务器公网 IP 地址
external-ip=YOUR_PUBLIC_IP

# STUN 服务
fingerprint
lt-cred-mech

# TURN 认证(使用用户名和密码)
user=exampleuser:examplepassword

# Realm(一个标识符,可以随便设置)
realm=example.com

# 使用 long-term credentials
lt-cred-mech

# 如果要记录日志,请取消注释
# log-file=/var/log/turnserver/turnserver.log
# simple-log

# 设置中继服务器的网络接口
relay-ip=YOUR_PUBLIC_IP

# 设置服务器的最大并发连接数
max-bps=0

# 设置监听的 IP 地址
listening-ip=0.0.0.0

# 使用身份验证时使用的密钥
# static-auth-secret=YOUR_SECRET_KEY
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37

将 YOUR_PUBLIC_IP 替换为服务器的公网 IP 地址,将 exampleuser 和 examplepassword 替换为你自己的用户名和密码。

启用服务并设置开机启动

编辑好配置文件后,保存并退出编辑器。然后启用 Coturn 服务并设置为开机启动:

sudo systemctl enable coturn
sudo systemctl start coturn
  • 1
  • 2

4. 防火墙配置

确保服务器的防火墙允许 STUN 和 TURN 相关的端口(通常是 3478 和 5349)。使用以下命令打开这些端口:

在 Ubuntu 使用 UFW
sudo ufw allow 3478/tcp
sudo ufw allow 3478/udp
sudo ufw allow 5349/tcp
sudo ufw allow 5349/udp
  • 1
  • 2
  • 3
  • 4
在 CentOS 使用 FirewallD
sudo firewall-cmd --zone=public --add-port=3478/tcp --permanent
sudo firewall-cmd --zone=public --add-port=3478/udp --permanent
sudo firewall-cmd --zone=public --add-port=5349/tcp --permanent
sudo firewall-cmd --zone=public --add-port=5349/udp --permanent
sudo firewall-cmd --reload
  • 1
  • 2
  • 3
  • 4
  • 5

5. 测试 Coturn 服务器

配置完成后,可以在 WebRTC 应用中测试新搭建的 STUN/TURN 服务器。将 WebRTC 连接配置中的 STUN/TURN 服务器 URL 修改为你自己的服务器 IP 地址:

const configuration = {
  iceServers: [
    { urls: 'stun:YOUR_SERVER_IP:3478' },
    { 
      urls: 'turn:YOUR_SERVER_IP:3478',
      username: 'exampleuser',
      credential: 'examplepassword'
    }
  ]
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

将 YOUR_SERVER_IP 替换为你的服务器的公网 IP,exampleuser 和 examplepassword 替换为配置文件中的用户名和密码。

6. Coturn 服务器常见配置说明

  • listening-port: 默认监听的端口是 3478,TURN 协议的标准端口。
  • tls-listening-port: 启用安全的 TLS 连接时的端口,默认是 5349。
  • user: 设置用户名和密码来控制访问。
  • realm: 这是一个标识符,可以是你的域名,用于身份验证。
  • external-ip: 服务器的公网 IP,尤其在服务器有内网 IP 时,需要手动指定公网 IP。
  • fingerprint: WebRTC 使用的一种安全标识。
  • lt-cred-mech: 开启长效凭证机制,用于身份验证。

7. 其他调试工具

  • 可以使用 trickle ICE 这个在线工具测试你搭建的 STUN/TURN 服务器是否正常工作:
    • Trickle ICE

总结

搭建自己的 STUN/TURN 服务器不仅能提升性能,还可以让你完全掌控网络连接配置,避免第三方服务器速度不稳定的影响。Coturn 是目前最流行的选择,使用起来也非常简单。搭建成功后,你可以随时调整配置,适应不同的网络需求。

注:本文转载自blog.csdn.net的MonkeyKing.sun的文章"https://blog.csdn.net/sunyuhua_keyboard/article/details/143230474"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

121
服务器
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2024 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top