mediasoup搭建公网webrtc服务器实操详细教程

1.概述        

        mediasoup是一个开源的WebRTC SFU服务器实现,由于优秀的性能表现广受webrtc开发者的青睐。下面我们来介绍一下mediasoup服务器的公网搭建过程。

2.申请云主机

        想要在公网搭建自己的webrtc服务器,必须要有自己的云主机。本人开通的是腾讯云的轻量应用服务器。由于centos系统目前已经停更,系统选用的是ubuntu 24.04 LTS,下面是本人云主机的配置:

        云主机实例创建完之后,接下来是配置云主机的防火墙,规则如下:

3.开发环境搭建

        登录上云主机后,就可以开始搭建开发环境了。

#安装nodejs、npm
sudo apt install -y build-essential
curl -sL https://deb.nodesource.com/setup_18.x | sudo -E bash -
sudo apt-get install -y nodejs

#拉取代码
git clone https://github.com/versatica/mediasoup-demo.git
cd mediasoup-demo

#安装服务端
cd server
cp config.example.js config.js
npm install

#创建https证书
mkdir certs
openssl req -new -newkey rsa:2048 -x509 -sha256 -days 3650 -nodes -out fullchain.pem -keyout privkey.pem

#安装app服务
cd ../app
#--legacy-peer-deps告诉npm忽略项目中引入的各个依赖模块之间依赖相同但版本不同的问题
npm install --legacy-peer-deps

以上命令为mediasoup编译安装命令,完成之后回到mediasoup-demo目录下,执行vi run.sh创建启动脚本,内容如下:

#!/bin/bash
export WEBPORT="3000"
#云主机内网地址
export MEDIASOUP_LISTEN_IP="192.168.xx.xx"
export MEDIASOUP_MIN_PORT="44440"
export MEDIASOUP_MAX_PORT="44500"
#云主机公网ip
export MEDIASOUP_ANNOUNCED_IP="**.**.**.**"

cd server
node server.js &
echo "server start up finish!"

cd ../app
gulp live &
echo "app start up finish!"

执行脚本

sh run.sh

mediasoup的server端和app端便开始运行 

[Browsersync] Access URLs:
 ----------------------------------------------
       Local: https://localhost:3000/?info=true
    External: https://xx.xx.xx.xx:3000/?info=true
 ----------------------------------------------
          UI: http://localhost:3001
 UI External: http://localhost:3001
 ----------------------------------------------
[Browsersync] Serving files from: ../server/public
[Browsersync] Watching files...
[Browsersync] Couldn't open browser (if you are using BrowserSync in a headless environment, you might want to set the open option to false)

客户端如果需要访问将https://xx.xx.xx.xx:3000/?info=true&roomid=123456的ip替换成云主机的公网ip地址即可在本地电脑的网页端访问,这里建议使用谷歌浏览器进行访问。效果如下图所示:

这里提供一个简单的mediasoup-worker中添加FlexFEC的示例代码,供参考: 1. 修改mediasoup-worker的SRTP模块,增加FlexFEC的解析和处理代码: ```c++ // 在SRTP模块中增加FlexFEC的解析和处理代码 bool SrtpSession::UnprotectRtp(const uint8_t* data, size_t len, uint32_t* ssrc, int* payload_type, bool* fec) { ... // 解析FlexFEC if (IsFlexFecPacket(data, len)) { // 将FlexFEC数据包标记为FEC *fec = true; // 处理FlexFEC包 HandleFlexFecPacket(data, len, ssrc, payload_type); } ... } void SrtpSession::HandleFlexFecPacket(const uint8_t* data, size_t len, uint32_t* ssrc, int* payload_type) { // 解析FlexFEC头部 FlexFecHeader flexFecHeader = ParseFlexFecHeader(data, len); // 获取FlexFEC的SSRC和Payload Type *ssrc = flexFecHeader.ssrc; *payload_type = flexFecHeader.payload_type; // 处理FlexFEC数据 // ... } ``` 2. 在mediasoup中启用FlexFEC,增加设置FlexFEC的参数: ```javascript // 在mediasoup的设置中增加设置FlexFEC的参数 const workerSettings = { ... rtp: { flexfecSsrc: 12345, // 设置FlexFEC的SSRC值 flexfecPayloadType: 127 // 设置FlexFEC的Payload Type } }; ``` 3. 在WebRTC中设置FlexFEC的参数,增加SDP中的FlexFEC相关参数: ```sdp // 在SDP中增加FlexFEC相关参数 m=video 9 UDP/TLS/RTP/SAVPF 96 97 98 99 100 101 102 122 127 a=rtpmap:96 VP8/90000 a=rtpmap:97 H264/90000 a=rtpmap:98 VP9/90000 a=rtpmap:99 H265/90000 a=rtpmap:100 VP8/180000 a=rtpmap:101 VP9/180000 a=rtpmap:102 H264/180000 a=rtpmap:122 H264/90000 a=rtpmap:127 FlexFEC/90000 // 设置FlexFEC的Payload Type a=mid:video a=ssrc:12345 cname:mycname a=ssrc-group:FID 12345 54321 a=rtcp-mux ``` 需要注意的是,这只是一个简单的示例代码,实际上添加FlexFEC需要涉及到更复杂的技术和代码实现。如果您需要在mediasoup中添加FlexFEC,建议寻求专业的技术支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值