各大主流媒体服务器的综合指标 PK

简述

随着互联网的发展,音视频行业越来越火,自然而然的流媒体服务器也是百花齐放。市面上也有很多种类的流媒体服务器,让人眼花缭乱。特别是对技术了解不深的朋友,更不知道怎么选择。
其实作为服务器,主要考察的无外乎几个核心指标,只要符合,基本上都是属于比较优秀的流媒体服务器。我简略说一说这些核心特性:

稳定性,性能,资源占用,并发能力,成本,可维护性

其实这些特性又不是独立存在的,相互影响彼此。比如:可维护性。可维护性分为两类,一个开发的可维护性,一个是运营的可维护性。开发的可维护性包括,软件整体架构清晰,模块耦合性低,层次清晰,
这样对于新业务的扩展比较容易,有问题也非常容易排查;这样的架构也为高效,稳定提供了基石;运营的可维护性,对于新业务的展开逻辑比较清晰,错误排查比较方便容易定位,运维人员维护性差的可能需要 3 个人,而维护性好的可以 1 个人搞定,大大节省了人员成本。同时,对硬件资源可以减少使用的台数,大大的节省运维费用。其实每一点都可以长篇累牍的去讲述它的优缺点,但偏离了本文的用意,这里就不一一列举了。

这里主要介绍几款个人感觉不错的流媒体服务器。 smart_rtmpd, nginx rtmp, srs, zlm 。明白人一眼就看出来,这些主要是 C, C++ 语言实现的服务器,没错。就像有的借助小汽车的底盘,有的借助摩托车地盘,
从起点很多别的语言的流媒体服务器就输了。 C, C++ 基本上属于性能最好的语言,性能上 C > C++, 不要和我抬杠说汇编。:)

名字开发语言
nginx rtmpC
smart_rtmpdC++
srsC++
zlmC++

基本情况介绍

smart_rtmpd 服务器

github 地址: https://github.com/superconvert/smart_rtmpd
gitee 地址: https://gitee.com/superconvert/smart_rtmpd

免费软件,支持 rtmp, rtsp, srt 推流,rtmp, rtsp, srt, hls, dash, http-flv, ws-flv, webrtc 拉流;支持 webrtc sfu 功能, 支持 VOD 功能,支持直播和录像; 特点,稳定,高效,简洁,跨平台,解压及运行,支持的操作系统 Windows, Ubuntun, CentOS, Debian, FreeBSD, ARM 64,无第三方依赖,基本上内核 + glibc 就能运行,软件体积非常小,配置相对简单,由于出道比下面三个晚,名气相对没有下面三个大。

nginx rtmp 服务器

github 地址:https://github.com/arut/nginx-rtmp-module
开源软件,由于 nginx rtmp 依托 nginx 底层,所以性能也是相对比较好的,但功能相对于其余三个,相对比较少一点,也是支持跨平台,需要准备第三方库及编译环境,针对不同的操作系统需要不同的环境配置进行编译适配,过多的功能和说明,请参考它们的 README.md

srs 服务器

github 地址:https://github.com/ossrs/srs
开源软件:srs 基于协程技术,对于单进程的能力挖掘相当强悍,单对于多核应用同时对于 webrtc 的功能支持也是比较全面。也是支持跨平台,需要配置对应的编译环境,过多的功能和说明,请参考它们的 README.md

zlm 服务器

github 地址:https://github.com/ZLMediaKit/ZLMediaKit
开源软件:目前是一个庞大的开发框架,不仅提供服务器的一些功能,还提供一些基础组件,对于国产化的相关规范支持的比较全。过多的功能和说明,请参考它们的 README.md

测试环境

测试一般分为三端,推流端,服务器,拉流端,为了保证公平公正合理的情况下,测试过程中,推流端不做任何更改,推流码率固定;拉流端不做任何更改;服务器端依次运行各个流媒体服务器软件,其它软硬件环境均保持不变。同样的硬件,既同样的 CPU, 内存,硬盘,网络。

软件条件说明:

服务器操作系统 Ubuntu 24.04.1 LTS ( 虚拟机 ) , CPU: 2 , Memory: 8G

软件编译器版本或源码分支说明
smart_rtmpdgcc 5.4.02024.09.16 乌班图多线程版本老的编译器进行编译,新编译器应该性能会更好
nginx rtmpgcc 13.2.0源码分支:2fb11dffaedc5af66b1442b0315c54a4b9da585d大家如果想验证测试结果可以自行选择最优分支进行验证
srsgcc 13.2.0源码分支:747831154742e6e4dee9b16f3a29fc6e01904e8c大家如果想验证测试结果可以自行选择最优分支进行验证
zlmgcc 13.2.0源码分支:da704ab2f1184c3c87be64fe18c9f413de101d0f大家如果想验证测试结果可以自行选择最优分支进行验证

推流软件

软件版本
OBS29.0.2
ffmpeg.exeversion 4.3.2-2021-02-02-full_build-www.gyan.dev Copyright © 2000-2021 the FFmpeg developers

拉流软件

软件版本
rtmpstress.exe
ffplay.exeversion 4.3.2-2021-02-02-full_build-www.gyan.dev Copyright © 2003-2021 the FFmpeg developers

测试场景及数据

测试分为三个场景,时延测试,拉流测试,推流测试

时延测试

推流 OBS + 浏览器网页截屏 ( 1920x1080, 8192 kb/s )
浏览器:在线秒表网页
测试协议:rtmp 推拉流

拉流 ffplay -fflags nobuffer rtmp://192.168.23.141:1935/live/stream
测试场景: 一路推流一路拉流,主要测试延时

说明smart rtmpdsrszlmnginx rtmp
1.1171.5061.6351.334
1.3371.6352.4511.333
1.2471.5072.1941.334
1.2461.5041.7211.291
1.3351.6443.4411.773
1.2871.5051.6771.290
1.2581.4601.6351.291
1.2471.5901.6341.290
1.3741.5481.6771.204
单位秒1.3761.6351.5921.376

拉流测试

推流 OBS ( 4096 kb/s )
测试协议:rtmp 推拉流
测试时长:10 分钟
拉流 rtmpstress.exe 一路推 800 路拉,主要系统指标

说明smart rtmpdsrszlmnginx rtmp
86%88%189%95.40%
123%98%200%97.40%
82%99%143%84.30%
23%53%OBS 断开,拉流 18794.80%
98%42%35.00%
89%6%95.50%
97%4%40.00%
102%OBS 断开,拉流全部断开94.80%
81%26.20%
38%95.00%
CPU 随机抽取 10 次
内存0.50%3.30%0.90%0.30%

结论 平均 CPU 占用率 smart_rtmpd 与 nginx rtmp 旗鼓相当,CPU 占用率相对较低,对于内存的占用也是相对较低,推拉流过程相对平稳,无异常,但 nginx rtmp 业务相对于其它三个服务器业务是最简单的,缓存或 IO 都是简化处理的,其次它是纯 C 实现的,语言上对性能的优化占有天然的优势。
压测过程中 srs 和 zlm 推流一段时间,推流端会产生断开现象,拉流端会出现全部断开的现象。
smart_rtmpd 的拉流链接由 800 路降低到 724 路, 而 nginx rtmp 的拉流链接数由 800 路降低到 664 路。
srs 协程模型只能用一个 CPU ,所以理论上 CPU 不会超过 100%

推流测试

说明smart rtmpdsrszlmnginx rtmp
CPU13.7% ~ 200%23.9% ~100%97.4% ~ 200%52.5% ~93.8%
内存13.60%6.00%11.90%0.40%
说明 top 查看网卡中断和服务器进程交替霸榜,CPU 大部分时间占用和 nginx 相差不多,但 CPU 最大值大于 nginx 。推流长时间有部分链接断开“协程(单进程,CPU 最大 100%, 推流长时间推流链接大量断开 )”推流长时间有部分链接断开top 查看网卡和服务器进程交替霸榜,表现相当不错,推流长时间链接没有断开

结论: CPU 表现相对优秀的是 nginx rtmp, smart_rtmpd
内存占用 smart_rtmpd 最多,不过缓冲队列是可配置的,没有降低配置降低内存占用,nginx rtmp 的内存占用比较优秀不过 smart_rtmpd, srs, zlm 的业务功能都比 nginx 复杂很多,内存占用过多是理所当然的,nginx 几乎就是做了一个简单解流封流转流的功能,所以系统的占用需求是最小的"

收尾

各位老铁想不想也想测试一下对比一下各个流媒体的性能呢?包括软件的便利性,兼容性,部署成本,维护成本,可维护性做一个全面的对比。欢迎各位老铁拿出您的数据与结论,选出您最喜欢的流媒体服务器。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值