SRS srs-bench

news/2024/7/10 21:43:17 标签: linux, 开源, 流媒体

1 srs-bench

 音视频压测工具,包括RTMP/FLV/WebRTC/GB28181等,未来还会完善。

SB(SRS Bench) is a set of benchmark and regression test tools, for SRS and other media servers, supports HTTP-FLV, RTMP, HLS, WebRTC and GB28181.

For RTMP/HLS/FLV benchmark, please use branch master.

1下载代码和编译:

git clone -b feature/rtc https://github.com/ossrs/srs-bench.git && 
cd srs-bench && make

编译依赖golang环境 ubuntu16.04安装高版本 golang 

flag provided but not defined: -mod

1.2 golang安装

到官网:All releases - The Go Programming Language查找对应的版本

wget https://www.golangtc.com/static/go/1.9.2/go1.9.2.linux-amd64.tar.gz --no-check-certificate

tar -xvf go1.20.linux-amd64.tar.gz 

vi ~/.bashrc
//设置环境变量

export GOPATH=$HOME/go_1.20/go
export PATH=$PATH:$GOPATH/bin

source ~/.bashrc

//test

go version
go version go1.20 linux/amd64

1.3 更改go源

make

下载依赖报错  

尝试手动下载 失败

go get -u golang.org/x/sys

更改GO源

t@ubuntu:~/go_1.20$ go env -w GOPROXY=https://goproxy.cn,direct

设置完之后,我以为直接生效了,又去go get了一下,发现还是报一样的错,有点失望,原来需要依赖于 go module 功能,即go的环境变量GO111MODULE要打开,如何打开?如下命令即可,在终端执行

go env -w GO111MODULE=on

下载依赖

go mod vendor

1.4 编译srs-bench 

make

编译会生成下面的工具:

  • ./objs/srs_bench 压测,模拟大量客户端的负载测试,支持SRS、GB28181和Janus三种场景。
  • ./objs/srs_test 回归测试(SRS),SRS服务器的回归测试。
  • ./objs/srs_gb28181_test 回归测试(GB28181),GB服务器的回归测试。
  • ./objs/srs_blackbox_test 黑盒测试(SRS),SRS服务器的黑盒测试,也可以换成其他媒体服务器。

Note: 查看工具的全部参数请执行./objs/xx -h

2 负载测试 单机 rtc 能力 

注意 srs-bench分支 不同分支测试目标不同

webrtc: feture/rtc分支  

rtmp;tree/srs-librtmp

2.1 启动srs

./objs/srs -c conf/console.conf

Player for Live

直播播放压测,一个流,很多个播放。

首先,推流到SRS:

2 .2obs推流 rtc

然后,启动压测,比如100个:

2.3 测试用例说明

通过 ./objs/srs_bench -h命令,我们可以查看srs-bench提供了哪些压测的手段:

2.4 压测播放rtc

./objs/srs_bench -sr webrtc://192.168.1.116/live/livestream -nn 100

2.5 sdata查看负载情况

压测过程如何查看srs服务器的性能呢,有两种方式:

  • 直接通过desktop提供的容器状态可视化看板,但是能看到的内容有限
  • 通过docker ps/sdat/top等命令来监测,监测的维度就比较多了

dstat -tglmsn --top-cpu --top-mem --top-io

srs server log 负载信息

srs服务没有开多进程或者多线程来处理高并发 内部通过协程来实现高并发 ,100多播放一路 1280*720  i5cpu 16G内存  cpu已占用 50% 内存剩余2G

2.6 官方压测数据

上述srs  下行播放并发压测比较简单 rtmp hls等压测 参照官网

SRS Server - 高性能、高并发、高扩展性和可读性的网络服务器架构 | SRS


http://www.niftyadmin.cn/n/5125821.html

相关文章

一文讲透 “中间层” 思想

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《EffectiveJava》独家解析》专栏作者。 热门文章推荐&…

记 : CTF2023羊城杯 - Reverse 方向 Blast 题目复现and学习记录

文章目录 前言题目分析and复习过程exp 前言 羊城杯题目复现: 第一题 知识点 :DES算法 : 链接:Ez加密器 第二题 知识点 :动态调试 : 链接:CSGO 这一题的查缺补漏: 虚假控制流的去除…

Vue 父子组件传参、插槽

setup 函数中有两个主要的参数:props、context 。 props 用于接收父组件传递过来的数据,父传子。 context 指的是 setup 的上下文,它有三个属性:attrs、slots、emit 。 attrs 用于:当父组件传递过来的数据&#xff…

修复mongodb未授权访问漏洞(漏洞编号:009711D8)

漏洞描述: MongoDB是用C编写的开源文档数据库。在刚安装完毕的时候MongoDB都默认有一个 admin数据库,此时admin数据库是空的,没有记录权限相关的信息!当admin.system.users一个 用户都没有时,即使mongodb启动时添加了–auth参数,如果没有在ad…

python:使用Flask-SQLAlchemy对数据库增删改查的简单示例

以下将介绍Flask-SQLAlchemy对数据库增删改查的简单示例。 一、安装所需的库 pip install flask flask-sqlalchemy flask-mysql 二、创建数据表 本示例使用mysql创建数据库和表 CREATE TABLE user ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(255) DEFAULT NULL…

在Eclipse中使用Junit

1、准备测试类 public class Calculator {private static int result;public void add(int n) {result result n;} public void substract(int n) {result result -1; //Bug:正确的应该是resultresult-n}public void multiply(int n) {// result result*n;方法未写好}publi…

linux上安装apktool反编译apk解析AndroidManifest.xml得到首页Activity

需求 在linux系统上反编译安卓app, 有些应用需要知道其主页Activity用于adb指令打开其主页。 安装 自动安装脚本 #!/bin/bashwget https://raw.githubusercontent.com/iBotPeaches/Apktool/master/scripts/linux/apktool -O ./apktool wget https://bitbucket.org/iBotPeac…

Docker添加软链接,解决c盘占用问题

Docker的文件,默认放在 c 盘,用多了很影响系统的速度。 解决方法: 为 Docker 路径添加软链接。 在 windows 搜索框,输入cmd ,以管理员身份运行 cmd * 执行命令: “C:\Program Files\Docker” 这个地址是…