案例:使用性能测试工具PR对某访问平台进行压力测试

本文主要是介绍案例:使用性能测试工具PR对某访问平台进行压力测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片

本次案例分享是通过性能测试工具PerformanceRunner(简称PR)查看某访问平台性能需求是否满足产品设计要求,总结测试阶段的测试以及分析测试结果,明确被测系统通过性能测试出现的问题。

表1-1 性能测试指标一览表

性能参数性能目标
有效工作时间系统应能保证 99.99%的时间按设计工作时间正常运行
响应时间人员信息登记提交及人员出入信息加载响应时间均在3s以下
并发用户

系统能够支持 500 以上用户的并发处理

表1-2 测试范围一览表

序号模块名称功能点功能概述
1人员信息登记人员信息登记提交提交人员基本信息到服务器保存
2人员出入信息人员出入信息加载加密人员出入信息页面

表1-3 测试环境配置表

用途硬件配置软件配置
应用服务器CPU:双核内存:16G;
应用分配内存:8G
操作系统:
windows10
测试客户端

CPU:双核内存:16G

应用分配内存:8G

操作系统:

windows10

浏览器:

Google Chrome

工具:

PerformanceRunner1.1.3

数据库服务器对应于应用服务器

测试策略

本次性能测试主要为500虚拟用户并发下,测试系统的运行情况,数据是否能够保证完整性,系统是能够保持稳定性,以及系统响应时间是否符合标准,具备较好的用户体验效果。

执行方式

使用第三方工具 Fiddler 录制脚本,导入到性能测试工具PerformanceRunner 中,根据用例场景,与项目组研发修改脚本细节,编写必填参数,集成测试环境调试后执行,使用资源管理器监控cpu 等系统参数的性能,并通过 PerformanceRunner的报告分析找出系统瓶颈。

测试工具

工具类型工具名称版本用途
性能测试工具PerformanceRunner1.1.3性能测试

典型场景测试结果与分析

1)并发测试测试用例:500个用户执行提交人员登记信息及,及加载人员出入信息页面。

2)实际结果:用户访问时,平均响应时间较快,为2.22 秒左右,符合客户要求。

3)用例描述如下:

基准测试测试用例
用例名称500个用户执行用例编号1
测试步骤1.部署性能测试环境
2.用 Fiddler 录制脚本
3.使用 PerformanceRunner 修改脚本后运行
场景设计1.设计用户数量 500
2.设计运行时间为 10 分钟
执行时间10分钟
预期结果1.页面响应时间平均值不超过 3 秒
2.CPU 使用率平均值不能高于 80%
3.物理内存使用率不超过 80%

PerformanceRunner 分析结果:

1)平均响应时间:(注:事务响应时间记录单位为毫秒)

图片

2)每秒事务数:

图片

3)事务对照表:

测试项事务名称平均响应时间/s每秒事务数
1人员信息提交submit1.06202.418tps/s
2人员信息提交+人员出入信息加载Total2.22

202.309tps/s

4)点击率和吞吐量:

每秒点击量吞吐量(兆)
6072.172

5)系统指标:

CPU 占用率内存占比
82%28..9%

结论

1)实际结果:在 500 并发用户访问时,所有事务响应时间均为 2 秒左右,在 秒内;服务器 CPU 使用率平均值过高,建议提升服务器硬件性能,或部署服务器集群,分离数据库系统。

2)每次测试过程的场景如下:

A.加压方式:以 500 用户压力测试为例,每10s同时加压 50 虚拟用户,全部运行。

B.稳定性持续时间:为了保证测试过程充分和数据准确,每次脚本运行时间持续 10分钟。

C.减压方式:每10s卸载100虚拟用户。

D.思考时间:忽略所有思考时间。

E.其他设置:完全模拟Chrome浏览器行为;模拟浏览器缓存;网络带宽不限。

总结:此次通过通过性能测试工具PerformanceRunner500虚拟用户并发测试时,事务响应时间基本平稳,但是系统资源中CPU占用过高,已超出服务器 80%,此次判定不通过。

这篇关于案例:使用性能测试工具PR对某访问平台进行压力测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643152

相关文章

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时

MySQL 数据库表与查询操作实战案例

《MySQL数据库表与查询操作实战案例》本文将通过实际案例,详细介绍MySQL中数据库表的设计、数据插入以及常用的查询操作,帮助初学者快速上手,感兴趣的朋友跟随小编一起看看吧... 目录mysql 数据库表操作与查询实战案例项目一:产品相关数据库设计与创建一、数据库及表结构设计二、数据库与表的创建项目二:员

MySQL进行分片合并的实现步骤

《MySQL进行分片合并的实现步骤》分片合并是指在分布式数据库系统中,将不同分片上的查询结果进行整合,以获得完整的查询结果,下面就来具体介绍一下,感兴趣的可以了解一下... 目录环境准备项目依赖数据源配置分片上下文分片查询和合并代码实现1. 查询单条记录2. 跨分片查询和合并测试结论分片合并(Shardin

C#中的Drawing 类案例详解

《C#中的Drawing类案例详解》文章解析WPF与WinForms的Drawing类差异,涵盖命名空间、继承链、常用类及应用场景,通过案例展示如何创建带阴影圆角矩形按钮,强调WPF的轻量、可动画特... 目录一、Drawing 是什么?二、典型用法三、案例:画一个“带阴影的圆角矩形按钮”四、WinForm