《JMeter从入门到精通》之一——开始你的第一个JMeter脚本JMeter是一款在国外非常流行和受欢迎的开源性能测试工具,像LoadRunner一样,它也提供了一个利用本地ProxyServer(代理服务器)来录制生成测试脚本的功能,但是这个功能并不好用。所以在本文中介绍一个更为常用的方法——使用Badboy录制生成JMeter脚本。简单的介绍一下Badboy。Badboy是一款不错的Web自动化测试工具,如果你将它用于非商业用途,或者用于商业用途但是安装Badboy的机器数量不超过5台,你是不需要为它支付任何费用的。也许是一种推广策略,Badboy提供了将Web测试脚本直接导出生成JMeter脚本的功能,并且这个功能非常好用,也非常简单。你可以跟着下面的试验步骤来迈出你在开源世界的第一步。1.通过Badboy的官方网站下载Badboy的最新版本;2.安装Badboy。安装过程同一般的Windows应用程序没有什么区别,安装完成后你可以在桌面和Windows开始菜单中看到相应的快捷方式——如果找不到,可以找一下Badboy安装目录下的Badboy.exe文件,直接双击启动Badboy;3.启动Badboy,你可以看到下面的界面。在地址栏(图中红色方框标注的部分)中输入你需要录制的Web应用的URL——这里我们以为例,并点击GO按钮开始录制。如果你用过LoadRunner之类的商业工具,对于这个操作一定不会陌生吧^_^4.开始录制后,你可以直接在Badboy内嵌的浏览器(主界面的右侧)中对被测应用进行操作,所有的操作都会被记录在主界面左侧的编辑窗口中——在这个试验中,我们在Yahoo的搜索引擎中输入JMeter进行搜索。不过你将看到,录制下来的脚本并不是一行行的代码,而是一个个Web对象——这就有点像LoadRunner的VuGen中的TreeView视图;5.录制完成后,点击工具栏中的“停止录制”按钮,完成脚本的录制;6.选择“File-ExporttoJMeter”菜单,填写文件名“login_mantis.jmx”,将录制好脚本导出为JMeter脚本格式。也可以选择“File-Save”菜单保存为Badboy脚本;7.启动JMeter并打开刚刚生成的测试脚本。也许你已经急不可待的准备开始尝试着用JMeter处理你手头的工作了^_^在下面的几节,我将继续为大家介绍如何在JMeter中完成一个测试场景的设置和JMeter测试结果分析入门,以及如何参数化JMeter脚本。当然,如果你的动手能力很强,几分钟你就可以熟悉这些内容。不过还是请允许我一点点由浅入深的来帮大家完成“JMeter从入门到精通”的过程。我相信在这个过程中你将会了解到更多有关性能测试的知识和经验,甚至包括一些LoadRunner等商业测试工具所无法提供给你的经验。理解JMeter聚合报告(AggregateReport)AggregateReport是JMeter常用的一个Listener,中文被翻译为“聚合报告”。今天再次有同行问到这个报告中的各项数据表示什么意思,顺便在这里公布一下,以备大家查阅。如果大家都是做Web应用的性能测试,例如只有一个登录的请求,那么在AggregateReport中,会显示一行数据,共有10个字段,含义分别如下。Label:每个JMeter的element(例如HTTPRequest)都有一个Name属性,这里显示的就是Name属性的值#Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100Average:平均响应时间——默认情况下是单个Request的平均响应时间,当使用了TransactionController时,也可以以Transaction为单位显示平均响应时间Median:中位数,也就是50%用户的响应时间90%Line:90%用户的响应时间Note:关于50%和90%并发用户数的含义,请参考下文:最小响应时间Max:最大响应时间Error%:本次测试中出现错误的请求的数量/请求的总数Throughput:吞吐量——默认情况下表示每秒完成的请求数(RequestperSecond),当使用了TransactionController时,也可以表示类似LoadRunner的TransactionperSecond数KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec另外,如果大家在使用JMeter的过程中遇到问题,建议先参考下面这篇文章其他有关JMeter和性能测试的文章请参见下面的链接使用JMeter分布式性能测试作为一个纯JAVA的GUI应用,JMeter对于CPU和内存的消耗还是很惊人的,所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至还会引起JAVA内存溢出的错误。不过,JMeter也可以像LoadRunner一样通过使用多台机器运行所谓的Agent来分担LoadGenerator自身的压力,并借此来获取更大的并发用户数。根据JMeter官方文档的署名,你需要自己完成这个配置,不过不用担心,这将非常简单^_^1.在所有期望运行JMeter作为LoadGenerator的机器上安装JMeter,并确定其中一台机器作为Controller,其他的机器作为Agent。然后运行所有Agent机器上的JMeter-server.bat文件——假定我们使用两台机器192.168.0.1和192.168.0.2作为Agent;2.在Controller机器的JMeter安装目录下找到bin目录,再找到JMeter.properties这个文件,使用记事本或者其他文字编辑工具打开它;3.在打开的文件中查找“remote_hosts=”这个字符串,你可以找到这样一行“remote_hosts=127.0.0.1”。其中的127.0..0.1表示运行JMeterAgent的机器,这里需要修改为“remote_hosts=192.168.0.1:1664,192.168.0.2:1664”——其中的1664为JMeter的Controller和Agent之间进行通讯的默认RMI端口号;4.保存文件,并重新启动Controller机器上的JMeter.bat,并进入Run-RemoteStart菜单项。看到啥了?^_^使用命令行方式运行JMeter脚本2.4.3Non-GUIMode(CommandLinemode)Fornon-interactivetesting,youmaychoosetorunJMeterwithouttheGUI.Todoso,usethefollowingcommandoptions-nThisspecifiesJMeteristoruninnon-guimode-t[nameofJMXfilethatcontainstheTestPlan].-l[nameofJTLfiletologsampleresultsto].-rRunallremoteserversspecifiedinJMeter.properties(orremoteserversspecifiedoncommandlinebyoverridingproperties)Thescriptalsoletsyouspecifytheoptionalfirewall/proxyserverinformation:-H[proxyserverhostnameoripaddress]-P[proxyserverport]Example:JMeter-n-tmy_test.jmx-llog.jtl-Hmy.proxy.server-P8000上面这段说明来自JMeter的官方用户手册。其中提到了使用命令行方式运行JMeter脚本的方法。只有几个简单的参数,很直观,用起来也很方便。好处是可以节省一些系统资源。今天尝试300个虚拟用户连续运行5分钟时——使用GUI方式,发现开始运行后不久UI就失去了响应,并提示一个有关AWT的错误,最终只能把Java进程结束掉。但是使用命令行方式时却很稳定。不过当在命令行方式下尝试500个虚拟用户连续运行5分钟时,JMeter抛出了一个OutofMemory的异常并退出了进程。Note:1.执行命令前要检查当前目录是否是%JMeter_Home%\bin目录;2.如果JMeter脚本不在当前目录,需要指定完整的路径;如果要把执行的结果保存在其他地方也要指定完整的路径。如何解决JMeter通过JDBC访问Oracle和MySQL的问题(留言中有TestPlan实例下载)JMeter的手册中描述了如何访问MySQL,但是没有说明如何访问Oracle。对于没有Java应用开发经验和对Oracle不是特别熟悉的朋友,可以参考这篇文章来简单、快速的配置好JMeter中的JDBC连接和JDBCRequest。步骤:1.新建一个ThreadGroup;2.新增JDBCConnectionConfiguration;3.点击新增的JDBCConnectionConfiguration,需要修改的参数包括:VariableName:可以先填一个Oracle,等会解释;DatabaseURL:jdbc:oracle:thin:@{host_IP_or_machine_name}:{Oracle监听器监听的端口}:{你的Oracle实例的名字}——大家要注意,“{}”大括号只是我用来说明用的,在配置JMeter时,请将“{}”大括号去掉^_^JDBCDriverclass:oracle.jdbc.driver.OracleDriverUsername:访问上面Oracle实例的用户名Password:对应的密码0.新增一个JDBCRequest,需要修改的参数包括:VariableName:和上面的JDBCConnectionConfiguration填写同样的内容。这里表示JDBCConnectionConfiguration建立一个名为Oracle的连接池,之后其它的JDBCRequest都共用这个连接池;Query:select*fromtable_name。这里建议打开你的数据查询工具,输入一条SQL查询语句,保证可以执行看到结果的,然后copy过来;0.新增一个ViewResultsTree;0.点击Run,查看结果。可以在Responsedatatab看到响应的返回结果。注意事项:1.执行时提示:NoSuitableDriver。在电脑上搜索一下classes12.jar这个文件,然后copy到JMeter的Lib目录下。如果找不到classes12.jar这个文件,就找找classes12.zip文件,然后把扩展名改为jar;2.执行时提示:ORA-00911:invalidcharacter。确保你在JDBCRequest里面的Query中输入的SQL语句是正确的。JMeter用户手册中关于配置通过JDBC对数据库性能进行测试的部分如下:另外,我做了两个TestPlan,一个是forOracle的,一个是forMySQL的,你可以点击下面的链接下载。JMeterTestPlanforOracleJMeterTestPl