Centos7.2+Coturn+SignalMaster 搭建WebRTC进行H5直播

2023-11-07 13:38

本文主要是介绍Centos7.2+Coturn+SignalMaster 搭建WebRTC进行H5直播,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一次写博客,主要是记录一下自己的收获,如果能帮助到有缘人也算是打击了万恶的资本家

一、介绍

Coturn

Coturn是内网穿透服务器,因为webrtc是实时互动直播技术,所以首选web,但web又是单方向通信,服务器无法直接访问到客户端,怎么办? 那么就使用内网穿透进行搭桥,可以让服务器找到客户端。

SignalMaster

SignalMaster 是信令服务器,现在解决了内网穿透的问题,那么下一步解决的就是流媒体服务器,其实webrtc也是通过推流、拉流的方式实现的,所以就要有一个中间的服务器,SignalMaster就可以理解成这个中间的服务器。

以上理解仅仅是个人见解,不代表任何第三方,不喜勿喷(反正咱的能用)

二、环境介绍

服务器使用阿里云的,服务器配置:1H2G 1Mbs ; 系统是 Centos7.2 。这个服务器是我个人的一个测试服务器,就是没事的时候瞎研究搞的一个。

域名是在阿里云经过备案的,ssl正式是阿里云的免费证书

看网上其他人的教程,说的是谷歌浏览器要用https请求协议,火狐可以使用http。所以为了兼容火狐和谷歌,这里使用https证书进行搭建(反正https也不要钱)

三、开始搭建

系统要个干净的,重做完系统的,因为Linux系统我理解的还是太少,所以就只能按部就班的去操作

3.1、Coturn搭建

安装openssl

yum install -y openssl openssl-devel

安装libevent

yum install -y libevent-devel 

安装git

yum install -y git

安装node

yum install -y nodejs

安装npm

#切换到下载位置
cd /usr/local
#下载node14
wget https://npm.taobao.org/mirrors/node/latest-v14.x/node-v14.6.0-linux-x64.tar.gz
#解压node
tar -zxvf  node-v14.6.0-linux-x64.tar.gz
#名字太长给他一个重命名
mv node-v10.14.1node-v14.6.0-linux-x64 node-v14.6.0
#编辑环境变量
vi /etc/profile
#把node添加到环境变量里面
export NODE_HOME=/usr/local/node-v14.6.0
export PATH=$PATH:$NODE_HOME/bin
#刷新环境变量
source /etc/profile

下载Coturn 直接从国内 的gitee下载,不要从github下载,我试过github上面的编译失败老版本的可以,但是github下载主要看脸

cd /homegit clone https://gitee.com/dation/coturn.git

编译并安装Coturn

cd coturn
./configure
make && make install

查看是否编译成功

which turnserver

 看到这个就表示编译并且安装成功

使用openssl生成证书

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

命令自行百度,我也不懂

可以自行切换到/etc目录下查看这两个问价你是否存在或者使用

ls -la /etc/turn_*

命令进行查看

配置coturn

#切换到/usr/local/etc目录下
cd /usr/local/etc
#复制 turnserver.conf.default 并且命名为 turnserver.conf
cp turnserver.conf.default turnserver.conf#cp /usr/local/etc turnserver.conf.default turnserver.conf centos这样操作会报错,不知道为啥

查看本机内网IP

ifconfig

 eth0当中的172.28.17.47就是本机的内网IP地址

编辑turnserver.conf

vim turnserver.conf

编辑命令怎么用自行百度

在文件的最下方添加以下配置信息

listening-device=eth0			        # 刚刚查到的网卡名称
listening-port=3478				        # Conturn 监听的端口号
tls-listening-port=5349			
listening-ip=xxx.xx.xx.xx			    # 内网IP
relay-device=eth0				        # 刚刚查到的网卡名称
relay-ip=xxx.xx.xx.xx				    # 内网IP
min-port=49512					
max-port=65535
external-ip=x.xxx.xx.x/xxx.xx.xx.xx		# 公网IP/内网IP
fingerprint
lt-cred-mech
realm=cyky.158xxx5.com			        # 域名不要抄写这个,用自己准备的域名
user=neu:123456				            # 用户名:密码
stale-nonce
no-loopback-peers
no-multicast-peers
mobility
no-cli
cert=/etc/turn_server_cert.pem		    # 刚刚生成的签名证书
pkey=/etc/turn_server_pkey.pem

启动Coturn

turnserver -o -a -f -r ronz -c /usr/local/etc/turnserver.conf

查看启动情况

turnutils_stunclient -p 3478 turnserver	# turnserver 为公网IP
#如果你的公网地址是:10.10.12.112 那么命令就应该是:
#turnutils_stunclient -p 3478 10.10.12.112

看到以下提示表示stun 启动成功

 

turnutils_uclient -v -t -T -W 123456 turnserver # -W 是我们上面在配置文件中配置的密码

这个我的一直没有成功,不知道什么原因,但是不影响使用。

到这里Coturn已经搭建完成了。

3.2 搭建信令服务器

下载SignalMaster

cd /home
git clone https://gitee.com/huangleizzz/signalmaster.git

依然从gitee上下载,国内速度更快

SignalMast安装依赖

cd signalmaster
npm install

修改配置文件

vim config/development.json

配置SignalMast

{"isDev": true,"server": {"port": 8888,"/* secure */": "/* whether this connects via https */","secure": true,"key": "/usr/lab_project/4666031_ronz.top.key",	"cert": "/usr/lab_project/4666031_ronz.top.pem","password": null},"rooms": {"/* maxClients */": "/* maximum number of clients per room. 0 = no limit */","maxClients": 0},"stunservers": [{"urls": "stun:10.10.12.112:3478"}],"turnservers": [{"urls": ["turn:10.10.12.112:3478"],"username": "neu","credential": "123456","expiry": 86400,"secret": "123123were"}]
}

把这里面的10.10.12.112替换成你实际的公网IP

说明:

server.port: 信令服务器监听的端口号
server.secure: 连接是否由 HTTPS 发起
server.key: 自己申请的 SSL 的私钥(.key 文件)所在的路径
server.cert: 自己申请的 SSL 证书(.pem 文件)所在的路径
stunservers.urls: stun 服务器的地址
turnservers.urls: turn 服务器的地址
turnservers.username: 上面配置的 turnserver 的用户名
turnservers.credential : 上面配置的 turnserver 的密码

启动

npm start

说明启动成功

访问测试

打开谷歌浏览器,输入 https://10.10.12.112:8888/socket.io/

10.10.12.112 替换成自己的服务器公网IP

如果在浏览器当中看到

表示已经 SignalMaster 信令服务器搭建成功。

但是现在这个情况看着是不会有任何问题,但是当测试系统运行的时候可能会有一个报错,

报错的位置在socket.io.js的111行,这个时候把foreach改成for就可以了。因为没有错误截图,所以就不放图片了。

最后搭建一个测试版本的webrtc测试一下

下载SimpleWebRTC(有能力的可以自己写一个demo)

cd /homegit clone https://gitee.com/huangleizzz/SimpleWebRTC.git

安装依赖

npm install 

修改源码

vim SimpleWebRTC/out/simplewebrtc-with-adapter.bundle.js

 

vim SimpleWebRTC/test/index.html

 

<!-- 替换这条语句中 src 的链接,google速度会慢,当然替换成本地jquery也是可以的 -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>    
<!-- 将上面的 src 的链接替换为下面这个 -->
<script src="https://cdn.bootcss.com/jquery/1.9.0/jquery.min.js"></script>
vim package.json
 "test-page": "echo \"open https://0.0.0.0:8443/test/\" && stupid-server -s -c ./4666031_ronz.top.pem  -k /etc/httpd/cert/4666031_ronz.top.key -h 0.0.0.0",#让系统支持https协议运行,所以把ssl证书添加到运行的命令当中

启动SimpleWebRTC

npm run test-page

打开浏览器 通过 https://域名:8443/test/ 就可以打开demo并且浏览器申请摄像头和mic权限,点击同意即可。共享桌面的功能偶尔的打开一次,但是有时候又会不显示,不知道为啥,希望看到并手动操作过的小伙伴给个提示

在这里要感谢一下

RonzL

我是通过他写的 Centos7 下搭建 Coturn + SignalMaster + SimpleWebRTCicon-default.png?t=M0H8https://blog.csdn.net/zhuxian1277/article/details/109393922

自己动手操作后的总结。

这篇关于Centos7.2+Coturn+SignalMaster 搭建WebRTC进行H5直播的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/363968

相关文章

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

linux解压缩 xxx.jar文件进行内部操作过程

《linux解压缩xxx.jar文件进行内部操作过程》:本文主要介绍linux解压缩xxx.jar文件进行内部操作,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、解压文件二、压缩文件总结一、解压文件1、把 xxx.jar 文件放在服务器上,并进入当前目录#

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景