性能测试场景是用来模拟模拟真实用户操做的工做单元,因此场景设计必定要切合用户的操做逻辑,jmeter主要是经过线程组配合其余组件来一块儿完成场景的设置。html
Jmeter线程组其实是简历一个线程池,而后根据用户的设置完成线程池的初始化,在运行时作各类逻辑处理java
上图是一个线程组的配置界面,下面咱们对具体的参数进行说明shell
是名称和注释的配置,这里根据本身要测试的场景设置就好,最好是见名知意服务器
在取样器错误后要执行的操做,也就是说在某一个请求出错后的异常处理方式,有5中方式并发
在大量用户并发请求时,服务器可能会出现错误响应,这属于正常现象,此时要把错误记录下来,继续后面的请求oop
运行的线程数设置,一个线程对应一个用户性能
好比说设置了50个线程,Ramp-up period设置10秒,那么每秒就会启动5个线程,若是设置0秒,那么50线程就会当即启动。测试
JMeter 全部的线程是一开始就建立完成的,只是递增的时候会按照上面的规则递增。若是选择了这个选项,则不会在一开始建立全部线程,只有在须要时才会建立。spa
若是不选择,在启动场景时,JMeter 会用更多的 CPU 来建立线程,它会影响前面的一些请求的响应时间,由于压力机的 CPU 在作其余事情嘛。若是选择了的话,就会在使用时再建立,CPU 消耗会平均一些,可是这时会有另外一个隐患,就是会稍微影响正在跑的线程命令行
Specify Thread lifetime 线程运行时间,这个配置只有Loop count 请求的重复次数,配置了infinite,才会生效,不然仍是Loop count 控制线程的执行
Jmeter的运行方式分为两种,一种是GUI可视化界面运行,另外一种是命令行运行,这两种都支持本地化运行即单体运行和远程运行。这里咱们主要介绍远程执行和jmeter命令行运行。
远程配置
远程运行节点端口配置:
server_port=1099 server.rmi.localport=1099
运行:
./jmeter-server -Djava.rmi.server.hostname=本机ip
本地配置
remote_hosts配置
remote_hosts=ip:port,ip:prot,... ip和port都是远程执行机的ip和server的运行端口
运行:
java -jar ApacheJMeter.jar -n -t Thread\ Group.jmx -r -l result.jtl -R ip
-R 指定要哪台机器运行测试脚本
命令行执行./jmeter -?能够输出命令行参数选项,这里只介绍一些比较经常使用的,更多用法看官方文档
欢迎你们去 个人博客 瞅瞅,里面有更多关于测试实战的内容哦!!