freeswitch带媒体压力测试方案

概述
原本的计划是使用sipp完成带媒体压力测试,但是实际测试过程中发现sipp的媒体处理功能有问题(也有可能是我使用的姿势不对)。
sipp在带媒体的情况下(600路并发开始),出现大量的不响应和响应延迟,UAC和UAS都有该问题,猜测是sipp内部处理大量媒体的情况下,业务逻辑出现阻塞。
新的方案采用2台fs对接,增加的1台fs模拟UAC和UAS,使用python脚本发起呼叫并控制并发。
环境
centos7.9
freeswitch 1.10.7
python2.7.5
freeswitch压力测试服务器配置,cpu96线程核,内存32G。
freeswitch模拟服务器配置,cpu16线程核,内存32G。
对接方案
2台fs对接带媒体压测方案,见图。

fs配置
fs压力测试服务器,IP地址为192.168.1.2,开放3060和5066端口。
压测服务器的呼叫A路从3060端口进入,从5066端口呼出B路。拨号计划如下。
cat sbc-dp.xml
<include>
<X-PRE-PROCESS cmd="set" data="callout_answer_timeout=60"/>
<context name="out2in">
<extension name="sbc-out2in" continue="true">
<condition field="${acl(${network_addr} 192.168.1.1/32)}" expression="true"/>
<condition field="destination_number" expression="^(\d+)$">
<action application="limit" data="hash cps all 500/1 !EXCHANGE_ROUTING_ERROR"/>
<action application="limit" data="hash capacity all 5000 !EXCHANGE_ROUTING_ERROR"/>
<action application="set" data="effective_caller_id_name=_undef_" />
<action application="set" data="effective_caller_id_number=${translate(${caller_id_number} GB-CALLER-IN)}" />
<action application="set" data="destination_number=${translate(${destination_number} GB-DEST-IN)}" />
<action application="set" data="inherit_codec=true"/>
<action application="export" data="absolute_codec_string=G729,PCMA" />
<action application="export" data="rtp_codec_negotiation=greedy" />
<action application="set" data="sip_copy_custom_headers=false"/>
<action application="export" data="passthrough180=true" />
<action application="export" data="ringback=${cn-ring}"/>
<action application="bridge" data="{sip_invite_call_id=${sip_call_id}
}sofia/external5066/sip:${destination_number}@192.168.1.1:5080"/>
</condition>
</extension>
</context>
</include>
fs模拟服务器,IP地址为192.168.1.1,开放5080端口,呼入呼出都使用5080端口。
模拟UAS侧的呼叫处理,拨号计划如下。
cat test.xml
<include>
<context name="public">
<extension name="sbc-uas" continue="true">
<condition field="destination_number" expression="^(\d+)$">
<action application="set" data="inherit_codec=true"/>
<action application="export" data="absolute_codec_string=PCMA" />
<action application="export" data="rtp_codec_negotiation=greedy" />
<action application="pre_answer" />
<action application="sleep" data="500" />
<action application="answer" />
<action application="playback" data="/usr/local/freeswitch/sounds/ponce-preludio-in-e-major" />
</condition>
</extension>
</context>
</include>
其中的playback放音文件要准备多个格式的文件,防止UAS侧因为转码而消耗cpu。
ll /usr/local/freeswitch/sounds/
-rw-r--r--. 1 root root 140220 4月 6 11:20 ponce-preludio-in-e-major.G729
-rw-r--r--. 1 root root 1121760 4月 6 11:20 ponce-preludio-in-e-major.PCMA
-rw-r--r--. 1 root root 2243628 10月 12 14:09 ponce-preludio-in-e-major.wav
模拟UAC侧的呼叫发起由python脚本实现,见下一章。
python脚本
python脚本中使用fs的esl接口对接,通过循环调用fs的originate接口发起呼叫,通过参数方式设置cps、duration、capacity等信息,通过配置文件方式设置主被叫号码。
cat test-media.py
# coding=utf-8
#!/usr/bin/python2
#add by zr 20230404
#大并发场景下的语音媒体流压力测试
#根据配置的号码,批量并发拨测
import ESL
import time
import sys
#USAGE: python test-media.py cps duration calltotal
#PS: python test-media.py 10 30 100
cps = int(sys.argv[1])
duration = int(sys.argv[2])
calltotal = int(sys.argv[3])
callinterval = float(1)/cps
print('cps=%d, duration=%d, calltotal=%d, callinterval=%f' % (cps, duration, calltotal, callinterval))
con = ESL.ESLconnection('localhost', '8021', 'ClueCon')
if con.connected():
pass
# con.events('plain', 'CHANNEL_CREATE')
#con.events('plain', 'CHANNEL_ANSWER')
#con.events('plain', 'CHANNEL_HANGUP')
else:
print("ESLconnection failed")
exit()
fo = open('./test_multi.ini', 'r')
while calltotal > 0:
line = fo.readline().strip()
if not line:
print('line is null')
fo.seek(0)
time.sleep(callinterval)
continue
if line.startswith('#'):
print('line is ###')
time.sleep(callinterval)
continue
calltotal = calltotal - 1
caller, callee = line.split(' ')
print('line=%s, %s' % (caller, callee))
callstr = ("originate {origination_caller_id_number=%s}"
"[absolute_codec_string=^^:G729:PCMA]"
"[execute_on_answer='sched_hangup +%d']sofia/external/%s@192.168.1.2:3060 "
"&echo()"
% (caller, duration, callee))
print('callstr=%s' % (callstr))
con.bgapi(callstr)
time.sleep(callinterval)
fo.close()
con.disconnect()
配置文件如下。
cat test_multi.ini
#caller callee
10000 20000
10001 20001
10002 20002
测试
使用python脚本发起呼叫测试。
脚本参数含义为,每秒发起1通,接通后10秒挂断,总共发起2通呼叫。
python test-media.py 1 10 2
cps=1, duration=10, calltotal=2, callinterval=1.000000
line is ###
line=10000, 20000
callstr=originate {origination_caller_id_number=10000}[absolute_codec_string=^^:G729:PCMA][execute_on_answer='sched_hangup +10']sofia/external/20000@192.168.1.2:3060 &echo()
line=10001, 20001
callstr=originate {origination_caller_id_number=10001}[absolute_codec_string=^^:G729:PCMA][execute_on_answer='sched_hangup +10']sofia/external/20001@192.168.1.2:3060 &echo()
总结
通过修改UAC侧的python脚本中的“absolute_codec_string”变量,和UAS侧的dialplan中的“absolute_codec_string”变量,可以对不同的媒体流方式进行压力测试。
脚本命令使用“python test-media.py 44 50 44000”,即每秒发起44通呼叫,接通50秒后挂断,总共发起44000通呼叫。
SBC的AB路媒体为PCMA-PCMA,压测结果如下。
82sps,4100session,cpu4.5%,A路带宽占用162Mbps,B路带宽占用162Mbps。
SBC的AB路媒体为G729-G729,压测结果如下。
82sps,4100session,cpu5.5%,A路带宽占用59Mbps,B路带宽占用59Mbps。
SBC的AB路媒体为G729-PCMA,转码场景压测结果如下。
42sps,2096session,cpu37%,A路带宽占用31Mbps,B路带宽占用85Mbps。
62sps,3176session,cpu60%,A路带宽占用46Mbps,B路带宽占用129Mbps。
80sps,4000session,cpu86%,A路带宽占用58Mbps,B路带宽占用160Mbps。
空空如常
求真得真
freeswitch带媒体压力测试方案的更多相关文章
- 4分钟apache自带ab压力测试工具使用: 2015.10.4
2015.10.44分钟apache自带ab压力测试工具使用:win8.1 wampserver2.5 -Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b 可以参考一下部 ...
- win8.1上wamp环境中利用apache自带ab压力测试工具使用超简单讲解
2015.10.4apache自带ab压力测试工具使用:本地环境:win8.1 wampserver2.5 -Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b 可以参考一 ...
- 网站服务器压力Web性能测试(1):Apache Bench:Apache自带服务器压力测试工具
一个网站或者博客到底能够承受多大的用户访问量经常是我们在用VPS或者独立服务器搭建网站了最关心的问题,还有不少人喜欢对LNMP或者LAMP进行一些优化以便提高Web性能,而优化后到底有多大的效果,就需 ...
- PHP测试与优化(1)-- Apache自带的压力测试工具ab(apache bench) - 简单使用
ab是apache自带的网站压力测试工具,能够测试网站在一定时间内的发生高并发时的反应. 使用 1.进入apache的bin文件夹 2.模拟并发级别为100,请求数为1000个的api数据请求数量测试 ...
- mysql 自带的压力测试
注意mysqlslap 是mysql5.1之后新添加的功能,之前的版本是没有此功能的
- (转)MySQL自带的性能压力测试工具mysqlslap详解
mysqlslap 是 Mysql 自带的压力测试工具,可以模拟出大量客户端同时操作数据库的情况,通过结果信息来了解数据库的性能状况 mysqlslap 的一个主要工作场景就是对数据库服务器做基准测试 ...
- 使用ab进行压力测试详解
ab是apache自带的压力测试工具,非常好用.转载几篇对ab工具的详细使用的博文.猛击下面的链接地址 http://www.365mini.com/page/apache-benchmark.htm ...
- GPS部标监控平台的架构设计(七)-压力测试
部标监控平台的压力测试是部标检测流程的最后一个检测环节,也是最难的,很多送检的企业平台都是卡壳在这一个环节.企业平台面临的问题如下: 1.对于压力测试的具体指标要求理解含糊,只知道是模拟一万辆车终端进 ...
- Nginx使用webbench进行压力测试
在运维工作中,压力测试是一项非常重要的工作.比如在一个网站上线之前,能承受多大访问量.在大访问量情况下性能怎样,这些数据指标好坏将会直接影响用户体验. 但是,在压力测试中存在一个共性,那就是压力测试的 ...
- 使用Apache Bench进行压力测试
Apache Bench是Apache中自带的压力测试工具 在linux中我们安装好apache后可以通过ab指令使用它 格式:ab [参数] [http://]ip地址/path/ 常用参数说明: ...
随机推荐
- Hnswlib 介绍与入门使用
Hnswlib是一个强大的近邻搜索(ANN)库, 官方介绍 Header-only C++ HNSW implementation with python bindings, insertions a ...
- 累加器Adder
① java8引⼊的,相⽐较是⼀个⽐较新的类 ② ⾼并发下LogAdder⽐AtomicLog效率⾼,不过本质是空间换时间 ③ 竞争激烈的时候,LongAdder把不同线程对应到不同的Cell上进⾏修 ...
- Kafka核心逻辑介绍
1.概念 Kafka是最初由Linkedin公司开发,是一个分布式.支持分区的(partition).多副本的(replica)分布式消息系统(kafka2.8.0版本之后接触了对zk的依赖,使用自己 ...
- 韩国国民搜索 NAVER:为 AI 平台引入存储方案 JuiceFS
NAVER 是一家多元化的互联网公司,拥有韩国最大的搜索引擎并在人工智能.自动驾驶等高科技领域积极投入. 在搭建 AI 平台时,NAVER 评估了公有云平台的存储产品.Alluxio 以及高性能专用存 ...
- Python——第五章:Zipfile模块
Zipfile模块 zipfile 模块是 Python 中用于处理 ZIP 文件的标准库模块.它提供了创建.读取和写入 ZIP 文件的功能. zipfile 模块在写入文件时,如果要将文件写入子目录 ...
- CentOS 7上使用Python 3和虚拟环境
在CentOS 7上使用Python 3和虚拟环境,请按照以下步骤操作: 首先,确保您的系统已安装Python 3.您可以使用以下命令检查Python 3是否已安装: python3 --versio ...
- TypeChat、JSONSchemaChat实战 - 让ChatGPT更听你的话
TypeChat 用一句话概括,就是用了它你可以让大语言模型(比如 ChatGPT)将自然语言转换成特定类型的 JSON 数据. 我们在使用 ChatGPT 的时候,大致流程如下: 假如我们需要 Ch ...
- 斯坦福 UE4 C++ ActionRoguelike游戏实例教程 07.在C++中使用UMG
斯坦福 UE4 C++ ActionRoguelike游戏实例教程 07.在C++中使用UMG 斯坦福课程 UE4 C++ ActionRoguelike游戏实例教程 0.绪论 概述 本篇文章的目标是 ...
- C#基于ScottPlot进行可视化
C#基于ScottPlot进行可视化 前言 上一篇文章跟大家分享了用NumSharp实现简单的线性回归,但是没有进行可视化,可能对拟合的过程没有直观的感受,因此今天跟大家介绍一下使用C#基于Scott ...
- 玩转Sermant开发,开发者能力机制解析
本文分享自华为云社区<开发者能力机制解析,玩转Sermant开发>,作者:华为云开源 . 前言: 在<Sermant框架下的服务治理插件快速开发及使用指南>中带大家一起体验了S ...