一、常见的压力测试性能指标

  • 响应时间(Response Time: RT):指用户从客户端发起一个请求开始,到客户端接收到从服务器端返回的响应结束所耗费的时间。
  • HPS(Hits Per Second):每秒点击次数,单位是次/秒。
  • TPS(Transaction per Second):系统每秒处理交易数,单位是笔/秒。
  • QPS(Query 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%的响应时间。
  • 从外部看,性能测试主要关注如下三个指标:
        吞吐量:每秒钟系统能够处理的请求数、任务数。
        响应时间:服务处理一个请求或一个任务的耗时。
        错误率:一批请求中结果出错的请求所占比例。

二、JMeter简介

        Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具,用于对软件做压力测试。

1.安装启动

JMeter 依赖于JDK,所以必须确保当前计算机上已经安装了 JDK,并且配置了环境变量。
Apache Jmeter官网下载,地址:http://jmeter.apache.org/download_jmeter.cgi

解压缩即可使用,目录结构如下:
        
运行bin目录下的jmeter.bat脚本即可启动JMeter:
        

2.汉化

        
        上面的配置只能保证本次运行是中文,如果要永久中文,需要修改 JMeter 的配置文件。打开 JMeter 文件夹,在 bin 目录中找到 jmeter.properties,添加下面配置:
language=zh_CN
        

3.★基本使用

  • 新增线程组(用来模拟用户),填写线程信息
  • 填写取样器(相当于测试的目标)内容,添加http请求

  • 添加监听结果树(用来查看测试的具体结果),并察看

  • 添加监听报告

    汇总报告结果

4.解决JMeter在Windows下地址被占用的BUG

        
        这个BUG是由Windows系统本身提供的端口访问机制的问题导致的。Windows 提供给 TCP/IP 链接的端口为 1024-5000,并且要四分钟来循环回收他们,这就导致我们在短时间内进行大量请求时将端口占满了。
  • cmd→regedit命令打开注册表
  • 在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters 下:
    • 右击 parameters,添加一个新的 DWORD,名字为 MaxUserPort;然后双击 MaxUserPort,输入数值数据为 65534,基数选择十进制(如果是分布式运行的话,控制机器和负载机器都需要这样操作哦)
    • 右击 parameters,添加一个新的 DWORD,名字为 TCPTimedWaitDelay;然后双击 TCPTimedWaitDelay,输入数值数据为 30,基数选择十进制(设置回收时间为30s)
    • 修改完以上配置后,重启电脑

三、性能

1.首先考虑自己的应用属于 CPU 密集型还是 IO 密集型

2.数据库
3.应用程序
4.中间件(tomact、Nginx)
5.网络和操作系统等方面