使用JMeter做性能测试的心得

 

 

from: http://www.javaeye.com/topic/211216

 

 

企业应用开发过程中,性能测试是很重要的一个环节,在这个环节中Apache的JMeter以它开源、100%纯Java、操作方便等优点发挥着很大的作用。

  经过一段时间的使用,多少有些心得和技巧,拿出来共享,希望能有些帮助。

  1、制作测试脚本:

  手工制作测试脚本,需要你知道请求的url和携带的参数等等,太花费时间。

  所以可以用badboy工具录制脚本。这个工具虽然不是开源的,但是却可以用来免费的录制成.jmx的脚本,使用起来很方便。

  官方网站是:http://www.badboy.com.au/

  2、出现乱码了?

  在用JMeter发行HTTPRequest时,在请求参数中有中文时,发现存储到DB中后,相应的字段是乱码。

  明明在参数后面的Encode选项中打了V。后来发现badboy录制脚本的时候并没有记录编码方式,所以修改脚本,在Content encoding中设置正确的编码方式就不会出现乱码了。

  3、JMeter的妙用---准备测试数据:

  要求性能测试开始前,先准备5W条数据。当然可以通过直接修改DB,但是如果这5W条数据涉及到很多表的关联,甚至还要通过存储过程的处理怎么办,直接修改DB很容易出现错误的数据,要是在客户的机器上弄错,可就闯祸了。

  这时候想到了JMeter,它本来是用来模拟大量用户并发请求的,现在用它来批量的生成数据吧。

  如果要求每条数据都不同,就要修改脚本,使用JMeter的函数来动态产生数据,比较常用的是CSVRead函数,记不住名的话Ctrl+F可 以呼唤出函数助手。使用这个函数的时候需要注意几点,首先是csv文件的编码格式,使用ansi没有问题,使用unicode时会使读取的第一行数据出现 错误;

  ${__CSVRead(data.txt,0)} ---读取本行的第一列值

  ${__CSVRead(data.txt,1)} ${__CSVRead(data.txt,next)} ---读取本行的第二列值,并把行标移动到下一行。

  试验证明JMeter应该做好了同步,在多线程环境下上面的调用方法没有问题;

  最后,修改JMeter的线程数会加快数据生成的速度,原理是当并发线程在20左右的时候会达到最大的吞吐量(request/分),所以应该设定线程数20左右。

  4、JMeter中debug方法:

  JMeter提供了log函数输出log,但是有时候并不好用,比如我想输出某个函数的返回值看是不是正确的。

  ${__log(${__CSVRead(data.txt,1)} )}这样的写法是错误的,JMeter会抛出异常,该怎么办呢?

  答案是巧用监听器(Listener)来输出想看到的数据,结果显示为树的那个监听器,它可以让你查看每个sampler的请求数据和响应数据,在请求数据中就有你想看到的信息。

  5、常用的功能:

  ● 使用HTTP Cookie Manager或URL重写实现同一线程内的多个请求共享Session。

  ● 把Login的请求放到只执行一次的控制器中,那么即使循环多次,Login也只请求一次。

  ● 如果想让多个线程在同一时刻同时请求,那么用Synchronizing Timer来做集合点。

  ● 为了节省系统资源,使用非窗口模式运行JMeter(jmeter -n -t test.jmx)。

  ● 如果模拟并发用户过多,比如200线程,那么可以分散到多台机器上运行Jmeter(比如4台电脑,每台50线程)。

  更多功能请参照使用手册:

  中文手册(未完成)http://wiki.javascud.org/pages/viewpage.action?pageId=5566

  6、在winnt系统上,使用perfmon来帮助Jmeter采集服务器的系统资源数据,可以配置log输出这些数据作为性能瓶颈分析时使用。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值