【网络通信 -- WebRTC】项目实战记录 -- linux 环境下 libmediasoup 编译与测试

【网络通信 -- WebRTC】项目实战记录 -- linux 环境下 libmediasoup 编译与测试

【1】编译配置 libwebrtc

【1.1】下载并配置 depot_tools

复制代码
下载 depot_tools
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
 
编辑 ~/.bashrc 将 depot_tools 添加到路径中
vim ~/.bashrc
export PATH=$PATH:/(path to depot_tools)/depot_tools
source ~/.bashrc
 
检查 depot_tools 是否安装配置成功
which gn
which gclient

【1.2】获取 WebRTC 源码

复制代码
获取 WebRTC 代码
fetch --nohooks webrtc
 
若其中发生中断则执行如下命令继续
gclient sync
 
切换到 m94 分支并同步
cd src
git checkout -b m94 branch-heads/4606
cd ..
gclient sync --nohooks
gclient runhooks
 
下载安装相关依赖
cd src
./build/install-build-deps.sh

【1.3】编译 WebRTC

复制代码
# 设置编译参数
gn gen out/m94 --args='is_debug=true is_component_build=false is_clang=false rtc_include_tests=false rtc_use_h264=true use_rtti=true use_custom_libcxx=false treat_warnings_as_errors=false use_ozone=true ffmpeg_branding="Chrome" proprietary_codecs=true use_glib=false rtc_use_dummy_audio_file_devices=true rtc_build_examples=false use_partition_alloc=false rtc_enable_protobuf=false rtc_build_json=true'

# 清理原编译文件
gn clean out/m94
 
# 编译
ninja -C out/m94

【1.4】获取 WebRTC 相关头文件与库

复制代码
mkdir /home/user/libwebrtc
find webrtc -name "*.h" | xargs -I {} cp --parents {} /home/user/libwebrtc

cp /home/user/webrtc/src/out/m94/obj/libwebrtc.a  /home/user/libwebrtc

【2】编译配置 libmediasoupclient

复制代码
获取 libmediasoupclient

git clone https://github.com/versatica/libmediasoupclient.git

---------------------------------------------------------------------------

编译 libmediasoupclient

cd libmediasoupclient
 
cmake . -Bbuild \
  -DLIBWEBRTC_INCLUDE_PATH:PATH=(webrtc 头文件路径) \
  -DLIBWEBRTC_BINARY_PATH:PATH=(webrtc 库文件路径)

cmake . -Bbuild \
  -DLIBWEBRTC_INCLUDE_PATH:PATH=./deps/libwebrtc/lib_webrtc_linux/webrtc_linux/src \
  -DLIBWEBRTC_BINARY_PATH:PATH=./deps/libwebrtc/lib_webrtc_linux
 
make -C build/

---------------------------------------------------------------------------

编译产物

# 头文件:路径/mediasoupclient/mediasoupclient.hpp
# 库文件:路径/libmediasoupclient.a

【3】编译运行 mediasoup-broadcaster-demo

mediasoup-broadcaster-demo 使用 libmediasoupclient 库实现向 mediasoup 服务器发布一个预设的视频流的功能

【3.1】编译 mediasoup-broadcaster-demo

复制代码
安装依赖
apt install libssl-dev pkg-config
apt install libcurl4-openssl-dev

---------------------------------------------

编译安装 cpr

注意 : 下载 tag 1.4.0

$ git clone https://github.com/libcpr/cpr
$ git clone https://github.com/whoshuu/cpr
$ cd cpr && mkdir build && cd build
$ cmake .. -DCPR_USE_SYSTEM_CURL=ON
$ cmake --build .
$ sudo cmake --install .

---------------------------------------------

下载及编译 mediasoup-broadcaster-demo

git clone https://github.com/versatica/mediasoup-broadcaster-demo.git
 
cmake . -Bbuild                                              \
  -DLIBWEBRTC_INCLUDE_PATH:PATH=(libwebrtc 头文件路径) \
  -DLIBWEBRTC_BINARY_PATH:PATH=(libwebrtc 库文件路径)   \
  -DOPENSSL_INCLUDE_DIR:PATH=(openssl 头文件路径)      \
  -DCMAKE_USE_OPENSSL=ON
 
make -C build

---------------------------------------------

【3.2】运行测试 mediasoup-broadcaster-demo

复制代码
cd build
 
# 指定 mediasoup 服务器的地址
export SERVER_URL=https://192.168.0.127:4443
 
# 指定房间号
export ROOM_ID=llo3ybo1
 
# 局域网中需要禁用 ssl,公网不用
export VERIFY_SSL=false
 
# 运行
./broadcaster

【4】MediaSoup 流媒体服务器推流的其他方法

【4.1】基于 FFMPEG 的广播方法

参见 【网络通信 -- WebRTC】项目实战记录 -- 基于 MediaSoup 的 FFMPEG 接入

【4.2】基于 runner365/cpp_streamer 的广播方法

复制代码
完成编译后执行如下命令即可实现向 MediaSoup 推流

./mediasoup_push_bench -i (媒体文件) -o "https://(mediasoup 服务器地址):4443?roomId=(房间ID)&userId=(用户ID)" -n (推流数量)

问题与解决方案

【1】depot_tools/ninja.py: Could not find Ninja in the third_party of

复制代码
解决方案
apt-get install ninja-build

【2】depot_tools / fetch:第8行:exec:python:未找到

复制代码
解决方案
ln -s /usr/bin/python2.7 /usr/bin/python

参考致谢

本博客为博主的学习实践总结,并参考了众多博主的博文,在此表示感谢,博主若有不足之处,请批评指正。

【1】Linux平台Mediasoup客户端开发指南

【2】ERROR: Cannot find Ninja

【3】C++ Requests: Curl for People

【4】runner365/cpp_streamer

相关推荐
Fisher3Star2 天前
mediasoup Transport详解与代码实现
webrtc
Fisher3Star2 天前
mediasoup中Node.js与Worker进程通信机制
网络·webrtc
911hzh3 天前
Flutter WebRTC iOS 原理解析:从 getUserMedia 到 Texture,讲清视频采集、纹理渲染与远端通话链路
flutter·ios·webrtc
shao9185163 天前
第12章Streaming(下):视频应用(1)——项目八:基于WebRTC+YOLO的实时目标检测
yolo·目标检测·webrtc·gradio·视频流·yolov10·流式传输
三十_4 天前
WebRTC 远端画面无法显示:ICE 与 SDP 时序问题深度解析与解决方案
webrtc
metaRTC6 天前
metaRTC8 成功适配 RTOS:开启 MCU/嵌入式实时音视频新时代
单片机·嵌入式硬件·webrtc·实时音视频·rtos
Fisher3Star6 天前
mediasoup中ip与announceAddress配置要点
webrtc·sdp
小柯博客7 天前
Amazon Kinesis Video Streams C WebRTC SDK 开发实战
c语言·开发语言·网络·stm32·嵌入式硬件·webrtc·yocto
RTC老炮8 天前
WebRTC下FlexFEC算法架构及原理
网络·算法·音视频·webrtc
换个昵称都难9 天前
webrtc源码下载(2026年4月)
webrtc