前言
在《一体化测试指标可视工程实践》中,我们分享了以趣链BaaS系统为例的测试实践路径,在后台收到读者们关于性能测试的留言。为此,本期将围绕如何进行产品性能测试这一话题,展开详细描述。
众所周知,一个优秀的系统/产品必然是极其注重用户体验的,因此在任意运行环境内,提供流畅、丝滑、平稳的服务能力至关重要,而性能测试则是实现上述能力的重要途径。在实践中,我们可以从如何设计全面的性能测试采集指标?如何实现性能可视化?这两个关键问题出发。
在采集指标方面,常见的有接口响应时间、TPS、成功率、接口请求总数、网络进出等等。但是性能问题又与CPU、内存、磁盘等数据资源的使用情况息息相关,例如常见的内存泄漏/内存溢出会导致系统崩溃卡顿,而网络传输过慢则容易影响接口请求速度,因此定位性能问题需要全方位排查各类影响因素。
一体化核心框架

上图所示,一体化测试中不同测试类型、测试实施均可抽象为:数据生成、数据存储、数据展示三个部分,下面将以性能测试实施为例,详细介绍上述三个核心环节的设计。
性能测试关键能力设计
数据生成
数据生成指通过采集器配合性能测试脚本进行压测生成数据,采集器即为性能测试的压测工具,目前,市面上已有大量优秀的开源性能测试工具,如:Apache JMeter,Gatling,Locust。那么我们该如何选取压测工具呢?笔者认为可从以下几方面考虑:
(1)是否支持被测系统运营的平台(软硬件环境、数据库环境);
(2)是否支持监控以及数据传输;
(3)是否能满足系统自定义的测试场景;
(4)维护成本;
数据存储
数据存储指将采集到的数据存储到数据库内,鉴于性能测试的特殊性,需要选用时序数据库,实现高性能地查询与存储时序型数据。当前市场上典型的时序数据库包括InfluxDB,KDB+,Prometheus,Graphite等。其中, InfluxDB被广泛应用于存储平台/系统的监控数据、实时数据等场景,该数据库支持任意类型的事件数据,也可对海量数据进行实时计算,是较为不错的数据存储工具。
数据展示
数据可视化展示的核心是:希望所有信息尽可能透明,并帮助测试人员直观展示产品的实际性能结果,便于产品研发及缺陷排查定位。可将数据展示与数据存储的数据源结合,借助自定义的数据查询语句生成数据展示模板,用于创建、共享、浏览结果数据。市场上此类开源可视化亦是非常丰富,但各产品的侧重点不同, 有以查询为主、报表为主,或可视化为主等不同类型。以Grafana为例,其作为可视化大型测量数据的开源程序,提供强大的可视化面板(Dashboard)并支持自定义图表和布局展示,包含度量仪表盘和图形编辑器,且支持Graphite、Zabbix、InfluxDB、Prometheus和OpenTSDB等数据源。
性能测试一体化实施衔接
为了实现性能测试一体化实施,数据生成模块需要具备数据采集和传输等能力,目前市面上的压测工具有Load Runner、Jmeter、Loadster、WebLoad等,从压测场景和可维护性等方面考虑,jmeter的可移植性、多线程更符合压测的场景,因此可通过jmeter脚本等工具进行自定义测试指标采集。
例如,在BaaS平台性能指标采集时,针对BaaS特有功能模块涉及到的服务进行服务资源使用情况的数据采集,结合性能基础指标采集tps、响应时间、接口请求数、网络传输速率等指标,通过后置监听器实时传输数据至数据存储模块;
数据存储模块需要具备实时存储海量数据的能力,考虑到性能测试的数据存储量较大,为了达到性能测试数据实时传输实时可视化展示的效果,需选择时序数据库以存储数据,目前市场上典型的时序数据库有prometheus、influxdb、KDB+等。在实践中,可针对数据采集层进行扩展,借助自定义配置实现数据采集模块灵活兼容上述不同类型的数据库,实现数据库选择的多样性可;
最后是数据展示模块,可充分借助各类开源可视化工具实现查询能力的扩展,适配数据存储层的各类数据查询语句,针对特定的测试场景自定义查询语句进行可视化图表展示。以Grafana适配为例,其提供大量的dashboard面板,具有简单、高效、易操作等特点,可通过自定义Json文件构造符合特定测试场景的dashboard展示,满足性能测试结果直观展示,此外还可支持指标面板变更、多集群共享面板等能力。

性能测试一体化实操
以Baas测试为例,数据压测选取jmeter作为压测工具,测试脚本按照Baas功能模块划分:主机管理、联盟链管理、监控模块,区块浏览器模块等分别运行各功能模块脚本进行压测,数据存储选取选择influxdb时序数据库,数据展示则选用对应支持influxdb数据源可视化的grafana。
▲jmeter压测并实时传输数据
jmeter的【后置监听器】负责将jmeter压测过程中数据进行实时传输至influxdb,整个数据传输的过程是如何实现的呢?具体的数据生成逻辑如下:
private void addMetrics(String transaction, SamplerMetric metric) {
// FOR ALL STATUS
addMetric(transaction, metric.getTotal(), metric.getSentBytes(), metric.getReceivedBytes(), TAG_ALL, metric.getAllMean(), metric.getAllMinTime(),
metric.getAllMaxTime(), allPercentiles.values(), metric::getAllPercentile);
// FOR OK STATUS
addMetric(transaction, metric.getSuccesses(), null, null, TAG_OK, metric.getOkMean(), metric.getOkMinTime(),
metric.getOkMaxTime(), okPercentiles.values(), metric::getOkPercentile);
// FOR KO STATUS
addMetric(transaction, metric.getFailures(), null, null, TAG_KO, metric.getKoMean(), metric.getKoMinTime(),
metric.getKoMaxTime(), koPercentiles.values(), metric::getKoPercentile);
metric.getErrors().forEach((error, count) -> addErrorMetric(transaction, error.getResponseCode(),
error.getResponseMessage(), count));
}
如下图,展示了后端监听器的参数信息。

以下针对后端监听器设计的关键参数信息进行了简要说明,便于大家理解相关过程。
(1)后端监听器实现选择:org.apache.jmeter.visualizers.backend.influxdbBackendListenerClient;
(2)influxdburl填写influx URL地址以及数据库名,eg:http://influxdb.performance.blocface.BaaS.hyperchain.cn/write?db=$数据库名;
(3)application:变量名;
(4)measurement:数据库表名,默认情况下会自动生成表名,不需要在数据库内单独建立;
(5)summaryonly:为true的情况下只输出所有请求的集合数据报告。为false的情况下,输出每条数据的详细报告,我们测试中选择为false;
(6)summaryRegex:正则表达式将与样本名称匹配并发送到后端,默认匹配所有;
(7)testtitle:测试名称,默认设置的是 Test Name;
(8)percentiles:要发送到后端的百分位数,多个值已 ;分割。填写:90;95;99;
(9)eventTags:自定义标签,测试填写参数为:1;
▲数据实时存储
jmeter实时传输的数据均会被存储至influxdb。需要注意的是,该过程会生成两个Measurements,分别为jmeter和events,其中jmeter表内存储了压测过程中生成的所有数据指标,而events则负责记录过程中的事件信息(在本过程中不是重点环节,不做详细展开)。
▲数据可视化展示
Grafana可直接将influxdb作为数据采集的数据源,支持通过自定义SQL按需查询各类指标。实践中, 可先执行添加数据源的操作:数据源(data source)进入数据库资源页面,测试人员通过添加数据源(add data source),输入数据库信息(influxdb url、database)。
随后,进行可视化页面编辑操作:例如,按需编辑dashboard、添加panel,grafana的panel支持表格(table)、列表(alert list)、热图(Heatmap)等多种可视化展示的方式,充分满足各类展示需求。
此外,测试人员还可以通过自定义编写查询语句来控制面板展示不同的图表。需要注意的是,不同的数据源可对应不同的Query Editor。假设 Grafana 与另一个时序数据库(Prometheus) 结合使用时,对应的查询语句时就换成了PromQL。
如下图所示,其application即为jmeter后置监听器内的application参数,transaction为jmeter脚本内的所有请求名称。

最终本例的性能一体化测试的结果节选如下:

总结
本文介绍了性能可视化测试的基本工具与路径,但这还远远不够,实践中往往需要根据不同的性能测试指标持续优化可视化页面,提升测试数据透明性,缩短测试问题定位排查时间,欢迎大家留言讨论。
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
ES一、简介1、ElasticStackES技术栈:ElasticSearch:存数据+搜索;QL;Kibana:Web可视化平台,分析。LogStash:日志收集,Log4j:产生日志;log.info(xxx)。。。。使用场景:metrics:指标监控…2、基本概念Index(索引)动词:保存(插入)名词:类似MySQL数据库,给数据Type(类型)已废弃,以前类似MySQL的表现在用索引对数据分类Document(文档)真正要保存的一个JSON数据{name:"tcx"}二、入门实战{"name":"DESKTOP-1TSVGKG","cluster_name":"elasticsear
文章目录1.任务背景2.任务目标3.相关知识点4.任务实操4.1安装配置JDK4.2启动FISCOBCOS4.3下载解压WeBASE-Front4.4拷贝sdk证书文件4.5启动节点4.6访问节点4.7检查运行状态5.任务总结1.任务背景FISCOBCOS其实是有控制台管理工具,用来对区块链系统进行各种管理操作。但是对于初学者来说,还是可视化界面更友好,本节就来介绍WeBASE管理平台,这是一款微众银行开源的自研区块链中间件平台,可以降低区块链使用的门槛,大幅提高区块链应用的开发效率。微众银行是腾讯牵头设立的民营银行,在国内民营银行里还是比较出名的。微众银行参与FISCOBCOS生态建设,一定
TCL脚本语言简介•TCL(ToolCommandLanguage)是一种解释执行的脚本语言(ScriptingLanguage),它提供了通用的编程能力:支持变量、过程和控制结构;同时TCL还拥有一个功能强大的固有的核心命令集。TCL经常被用于快速原型开发,脚本编程,GUI和测试等方面。•实际上包含了两个部分:一个语言和一个库。首先,Tcl是一种简单的脚本语言,主要使用于发布命令给一些互交程序如文本编辑器、调试器和shell。由于TCL的解释器是用C\C++语言的过程库实现的,因此在某种意义上我们又可以把TCL看作C库,这个库中有丰富的用于扩展TCL命令的C\C++过程和函数,所以,Tcl是
文章目录一、项目场景二、基本模块原理与调试方法分析——信源部分:三、信号处理部分和显示部分:四、基本的通信链路搭建:四、特殊模块:interpretedMATLABfunction:五、总结和坑点提醒一、项目场景 最近一个任务是使用simulink搭建一个MIMO串扰消除的链路,并用实际收到的数据进行测试,在搭建的过程中也遇到了不少的问题(当然这比vivado里面的debug好不知道多少倍)。准备趁着这个机会,先以一个很基本的通信链路对simulink基础和相关的debug方法进行总结。 在本篇中,主要记录simulink的基本原理和基本的SISO通信传输链路(QPSK方式),计划在下篇记
目录一、ESP32简单介绍二、ESP32Wi-Fi模块介绍三、ESP32Wi-Fi编程模型四、ESP32Wi-Fi事件处理流程 五、ESP32Wi-Fi开发环境六、ESP32Wi-Fi具体代码七、ESP32Wi-Fi代码解读6.1主程序app_main7.2自定义代码wifi_init_sta()八、ESP32Wi-Fi连接验证8.1测试方法8.2服务器模拟工具sscom58.3测试代码8.4测试结果前言为了开发一款亚马逊物联网产品,开始入手ESP32模块。为了能够记录自己的学习过程,特记录如下操作过程。一、ESP32简单介绍ESP32是一套Wi-Fi(2.4GHz)和蓝牙(4.2)双模解决方
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。我使用PHP的时间太长了,对它感到厌倦了。我也想学习一门新语言。我一直在使用Ruby并且喜欢它。我必须在Rails和Sinatra之间做出选择,那么您会推荐哪一个?Sinatra真的不能用来构建复杂的应用程序,它只能用于简单的应用程序吗?
📝学技术、更要掌握学习的方法,一起学习,让进步发生👩🏻作者:一只IT攻城狮。💐学习建议:1、养成习惯,学习java的任何一个技术,都可以先去官网先看看,更准确、更专业。💐学习建议:2、然后记住每个技术最关键的特性(通常一句话或者几个字),从主线入手,由浅入深学习。❤️《SpringCloud入门实战系列》解锁SpringCloud主流组件入门应用及关键特性。带你了解SpringCloud主流组件,是如何一战解决微服务诸多难题的。项目demo:源码地址👉🏻SpringCloud入门实战系列不迷路👈🏻:SpringCloud入门实战(一)什么是SpringCloud?SpringCloud入门实战