博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Jmeter 双11电商性能测试总结】--未编写完善,目前只拟个思路记录下,后面时间充裕了再整理。...
阅读量:6610 次
发布时间:2019-06-24

本文共 1965 字,大约阅读时间需要 6 分钟。

hot3.png

前言:

        因业务需要,在双11来临之际需要对多个业务核心接口做压测工作,话不多说,直接记录(以下记录为本人的切实感受,不代表任何立场,如有出入请另行百度,本人只做比较,方便日后回顾,谢谢)

        

个人从以下几个角度进行阐述和总结:

1、压测常识

2、服务器性能监控范围

3、脚本编写与压测策略

4、压测实战

5、压测结果查看与分析

6、异常问题定位与分析

7、服务器性能监控

8、JVM监控

9、测试报告

10、踩过的坑

 

467aaace3e0d51858100f8747a48dd3cdb1.jpg

 一、压测常识:

负载测试:

通过逐步加压的方法,达到既定的性能阈值的目标,阈值的设定应是小于某个值,如cpu使用率小于等于80%

压力测试:

通过逐步加压的方法,使得系统的某些资源达到饱和,甚至失效的状态,简单粗暴的解释就是什么条件能把系统压崩溃

并发测试:

在同一时间內,多个虚拟用户在同时访问同一个模块,同一个功能,通常的测试方法就是设置集合点

容量测试:

通常是指数据库层面的,目标是获取数据库的最佳容量能力。又称为容量预估。具体测试方法为在一定的并发用户,不同的技术数据量下,观察数据库的处理能力,即获取数据库的各项性能指标

可靠性测试:

又称为稳定性测试或疲劳测试。是指系统在高压情况下,长时间的运行是否稳定。

cpu使用率在80%以上,7*24小时的运行,系统是否稳定

异常测试:

又称为失败测试。是指系统架构方面的测试,如在负载均衡中,要测试宕机,节点挂掉等情况的系统反映

事物

从客户端发起的一个请求或多个请求(这些请求组成一个完成的操作),到客户端收到服务器返回的响应

请求响应时间

客户端发起的一个请求开始,到客户端接收从服务器返回的响应,整个过程所耗费的时间

事物响应时间

事务可能是一个或者多个请求组成的,事物响应时间主要针对于用户的角度而言,如转账

 

并发

没有严格意义上的并发。并发总有先后,无论差距是1毫秒还是1微秒,总有一个时间差。所以并发讲的是一个时间范围内,比如1S内,

举例:

1、多用户在系统上进行同一操作,比如双11,大家针对同一种商品进行秒杀

2、多用户在系统上进行不同操作,比如双11,大家针对不同商品进行秒杀,或者大家有进行其他操作,比如商品浏览

并发用户数

同一单位时间内,对系统发起请求的用户数量

吞吐量

一次性能测试过程中网络上传输数据量的总和

 

二、服务器监控范围

1、CPU

2、磁盘

3、内存

4、网络

5、版本

6、性能损耗的计算方式(怎么计算性能损耗:相同的指标,相同的场景,相同的用户并发数进行多次同样的压测)

 

三、脚本编写与压测策略

1、由简单到复杂:先压单一场景,再压复杂场景

2、由优先级高到低:先压重点业务点,再压次要的

3、由单独到并行:先单独压业务点,再同时并行压业务点,因为生产场景是多个业务点在操作

PS:脚本编写,我这边全程用Jmeter3.3版本进行编写,这里我认为压测控制好合适的 线程数、持续时间、循环次数这是性能开始的核心,

如果想要测试出接口的拐点,则直接把线程数设置稍微大一点,持续时间设置短一点(我一般设置60S,线程数看接口性质,如果是dubbo接口我会设置稍微大一点,如果是普通的http接口,一般先设置100个线程数,然后逐步加压,一直压到服务器性能在一个峰值出现拐点后,大概就可以看出该接口的QPS是多少了)

520e6a42d9bb227f63c32e0f4aa1aa6d3ec.jpg

 

四、压测实践

PS:本人是在公司内网环境下进行压测的,那么压测服务机与压力机则会在同一网段下,不然会受带宽限制影响,那样压出来的测试结果则测不出接口性能瓶颈,

1、下载Jmeter zip包到服务器

2、解压unzip apache-jmeter-3.3.zip

3、给jmeter.sh 赋权 ,进到解压目录的 /jmeter/bin 下,chmod 777 jmeter.sh,可用  sh jmeter.sh -v 来检测命令是否可用

bbe4cf503957c454bd27ee15d0dd0ce73e2.jpg

8ba0e174dccb4c9baa1debed2b281054384.jpg

023c0345ff1a3b01438d8de84c1281c764d.jpg

 

五、异常问题定位与分析

52b90a541cd736acd167925146dafbbbfb9.jpg

 

六、服务器监控(nmon)

97944fdfa9e57d7a46fa156135614523f1e.jpg

328997af6c5b7caad7523da5869c3871e42.jpg

3442dd22ef5813a4791a7568e380fff2511.jpg

 

七、服务器性能监控结果

b209eb5d1959116ca39916b23a3337c9b19.jpg

3453ed72070fc07929b9f2b1df2a193490c.jpg

5c7ff58c579376234854c69a96b02d04e52.jpg76b9b841b07d033cb845b6314497ab237bf.jpg6b98aa0dccad1b4699a63e20bfcebc525db.jpg

3f734863aae8c4443b4580bad06fff635b5.jpg

 

八、JVM监控-Jprofiler

0735e0c41c37ea845a349ed4982348c6e7c.jpg

50e02c4fba70780bcfc5736f2dc28a4fd63.jpg

7cba7fbd2d4c1c0d32914fe8a9a25c499ef.jpg

1e35310911725cdf9c7f41a7c55c9a64105.jpg

10a5c83f1a63b38b91be19431f8fa7e2163.jpg

bb94d567db3a97a865d947bd677321cb028.jpg

7c833055ea77e1b76e082a584192e36f8ad.jpg

35bb632c469054a2a6d9e26442e9aa965f7.jpg

9d3978d68cd51a89260703baf17236c127b.jpg

f8b94c6ebfd6ede1717560d6200639776b4.jpg

 

九、测试报告

52430d1ffff34c1382245034f016cbb175d.jpg

十、做压测踩过的坑

1、做压测时,没有配置host,后果会导致qps很低,几乎为0

2、不熟悉业务操作时,或者数据层面的转换,可找测试同学确认操作或者找开发确定数据(数据能永久用的,就准备好sql脚本,结果就是省时省力)

3、造数据(测试优惠券的时候,一张券只能领一次,为了1W张券能重复领取,需要改数据库优惠券状态)

4、测试报告(前期没规范,一顿瞎捣鼓)

5、压测环境相对的稳定性(不要三天段电,两天断网的,重启服务太多了,中间件等,恶心)

JVM监控-JprofilerJVM监控JVM监控-Jprofiler-Jprofiler

转载于:https://my.oschina.net/u/3222944/blog/2991076

你可能感兴趣的文章
CSS hack
查看>>
IT项目管理工具探讨之_项目群管理
查看>>
如何在 Android 手机上安装 Ubuntu 13.04
查看>>
HDU 6073 - Matching In Multiplication | 2017 Multi-University Training Contest 4
查看>>
编程面试过程中常见的10大算法(转)
查看>>
centos6.5 安装nginx
查看>>
生成若干个不重复的随机数数组
查看>>
topcoder srm 465 div1
查看>>
C语言 scanf()和gets()函数的区别
查看>>
如何检测域名是否被微信屏蔽 微信域名检测接口API是如何实现
查看>>
POJ1611-The Suspects
查看>>
ROS学习之ShadowRepository
查看>>
Spring 中 ApplicationContext 和 BeanFactory 的区别
查看>>
3.28Day09函数
查看>>
Linux Makefile 生成 *.d 依赖文件及 gcc -M -MF -MP 等相关选项说明【转】
查看>>
Linux下安装Python-3.3.2【转】
查看>>
STL杂记
查看>>
LeetCode OJ:Merge Two Sorted Lists(合并两个链表)
查看>>
功能测试
查看>>
Rust的闭包
查看>>