性能测试设计

需求:如何设计一个5W并发量的性能测试场景?

 1、确定性能测试工具,性能测试思路

  a、工具:JMETER

  b、并发设计思路:如果被测服务足够快,比如10ms的响应时间,1个线程/秒就是100tps,5万的TPS,就得启动500个JMETER线程。

      测试时可以多加20%~50%的线程,连续阶梯加压看TPS完整过程,根据实际情况选择发压服务器配置。

  c、Jmeter能启动多少线程:

      c1、线程数受什么影响?jmeter是一个Java进程,一个Java进程下的线程数受什么影响?由堆内存、栈内存以及可用空间(本机的物理内存的剩余内存)决定的。

      c2、以Jmeter 5.1版本为例。在Jmeter.bat文件设置堆内存(注意:一般而言,堆的最大值不要超过物理内存的一半,否则容易导致jmeter运行变慢、卡顿甚至内存溢出,

        因为java本身的垃圾回收机制是动态分配内存。)

 

  d、当需要模拟的线程数较大时,就需要根据具体情况采用分布式压测的方式了。

2、确定项目架构,以及环境

  1、需要确定项目架构,包括不限于:服务器、数据库、中间件,整个链路

  2、确定测试环境服务器等资源,与生产对比(成比例)

 

3、确定业务需求

  a、单接口

  b、多接口(事务)

  c、确定业务量:峰值、日业务量、半年/一年的业务量

 

4、编写性能测试用例、脚本、执行场景

  a、性能测试用例(模板)

 

 

  b、性能测试脚本(JMETER)

    1、CSV参数化

    2、参数提取(正则表达式)

    3、断言

    ...................等等

  c、执行场景

    1、基准测试:1个并发执行5分钟,关注tps、响应时间、运行次数等参数

    2、负载测试:多个并发执行5分钟,关注tps、响应时间、运行次数、服务器的cpu、内存等参数

    3、阶梯测试:通过不断增压,找到拐点。关注tps、响应时间、运行次数、服务器的cpu、内存等参数

    4、疲劳测试:多并发,7*24小时运行,无报错异常。(根据实际情况执行,有的要求持续运行8小时即可)

5、调优、报告

  1、首先在服务器执行top命令,查看CPU消耗,us、sy哪个消耗的比较多

  2、找到消耗cpu的线程,再找到线程调用的方法。

  3、如果内存消耗比较多,检查日志级别。查看IO状况。

  4、检查是否存在慢sql。

posted @ 2022-04-26 10:33  测试-知秋  阅读(159)  评论(1)    收藏  举报