压力测试和JMeter使用分析
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
压力测试考察当前软硬件环境下系统所能承受的最大负荷并帮助找出系统瓶颈所在。
压测都 是为了系统在线上的处理能力和稳定性维持在一个标准范围内做到心中有数。
使用压力测试我们有希望找到很多种用其他测试方法更难发现的错误。
有两种错误类型是:内存泄漏并发与同步。
有效的压力测试系统将应用以下这些关键条件:重复并发量级随机变化。
1、性能指标
响应时间Response Time: RT
响应时间指用户从客户端发起一个请求开始到客户端接收到从服务器端返回的响 应结束整个过程所耗费的时间。
HPSHits Per Second
每秒点击次数单位是次/秒。
TPSTransaction per Second
系统每秒处理交易数单位是笔/秒。
QPSQuery per Second
系统每秒处理查询次数单位是次/秒。 对于互联网业务中如果某些业务有且仅有一个请求连接那么 TPS=QPS=HPS一 般情况下用 TPS 来衡量整个业务流程用 QPS 来衡量接口查询次数用 HPS 来表 示对服务器单击请求。
无论 TPS、QPS、HPS,此指标是衡量系统处理能力非常重要的指标越大越好根据经验一般情况下:
金融行业:1000TPS~50000TPS不包括互联网化的活动
保险行业:100TPS~100000TPS不包括互联网化的活动
制造行业:10TPS~5000TPS
互联网电子商务:10000TPS~1000000TPS
互联网中型网站:1000TPS~50000TPS
互联网小型网站:500TPS~10000TPS
最大响应时间Max Response Time
指用户发出请求或者指令到系统做出反应响应 的最大时间。
最少响应时间Mininum ResponseTime
指用户发出请求或者指令到系统做出反应响 应的最少时间。
90%响应时间90% Response Time
是指所有用户的响应时间进行排序第 90%的响应时间。
从外部看性能测试主要关注如下三个指标
吞吐量:每秒钟系统能够处理的请求数、任务数。
响应时间:服务处理一个请求或一个任务的耗时。
错误率:一批请求中结果出错的请求所占比例。
2、JMeter
1、JMeter 安装
https://jmeter.apache.org/download_jmeter.cgi
下载对应的压缩包解压运行 jmeter.bat 即可
2、JMeter 压测示例
添加线程组
线程组参数详解
线程数:虚拟用户数。一个虚拟用户占用一个进程或线程。设置多少虚拟用户数在这里 也就是设置多少个线程数。
Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果 线程数为 10准备时长为 2那么需要 2 秒钟启动 10 个线程也就是每秒钟启动 5 个 线程。
循环次数:每个线程发送请求的次数。如果线程数为 10循环次数为 100那么每个线 程发送 100 次请求。总请求数为 10*100=1000 。如果勾选了“永远”那么所有线程会 一直发送请求一到选择停止运行脚本。
Delay Thread creation until needed:直到需要时延迟线程的创建。
调度器:设置线程组启动的开始时间和结束时间(配置调度器时需要勾选循环次数为 永远)
持续时间秒:测试持续时间会覆盖结束时间
启动延迟秒:测试延迟启动时间会覆盖启动时间
启动时间:测试启动时间启动延迟会覆盖它。当启动时间已过手动只需测试时当前 时间也会覆盖它。
结束时间:测试结束时间持续时间会覆盖它。
添加 HTTP 请求
添加监听器
启动压测&查看分析结果
结果分析
有错误率同开发确认确定是否允许错误的发生或者错误率允许在多大的范围内;
Throughput 吞吐量每秒请求的数大于并发数则可以慢慢的往上面增加;若在压测的机 器性能很好的情况下出现吞吐量小于并发数说明并发数不能再增加了可以慢慢的 往下减找到最佳的并发数;
压测结束登陆相应的 web 服务器查看 CPU 等性能指标进行数据的分析;
最大的 tps不断的增加并发数加到 tps 达到一定值开始出现下降那么那个值就是 最大的 tps。
最大的并发数:最大的并发数和最大的 tps 是不同的概率一般不断增加并发数达到 一个值后服务器出现请求超时则可认为该值为最大的并发数。
压测过程出现性能瓶颈若压力机任务管理器查看到的 cpu、网络和 cpu 都正常未达到 90%以上则可以说明服务器有问题压力机没有问题。
影响性能考虑点包括: 数据库、应用程序、中间件tomact、Nginx、网络和操作系统等方面
首先考虑自己的应用属于 CPU 密集型还是 IO 密集型
感谢黑暗大帝赏脸 感谢黑暗大帝赏脸 感谢黑暗大帝赏脸 感谢黑暗大帝赏脸 感谢黑暗大帝赏脸