的录制回放功能是现将你对要的项目进行访问的历史记录进行录制,然后虚拟出多个用户对历史记录进行回放,从而达到的目的。
录制是通过代理服务器进行录制。
一、下载地址
http://labs.xiaonei.com/apache-mirror/jakarta/jmeter/binaries/jakarta-jmeter-2.3.2.zip
二、JMeter 的安装非常简单,从官方网站上下载,解压之后即可使用。运行命令在%JMETER_HOME%/bin 下,对于 用户来说,命令是 jmeter.bat。
三、录制。
1)新建代理服务器。
设置端口[8080]。
正则表达式填写排除模式(选填)。
i. .* - all
ii. .*.png – png images
iii. .*.gif – gif images
iv. .*.jpg – jpeg images
v. .*.php
vi. .*.jsp
vii. .*.html
viii. .*.htm
ix. .*.js
2)浏览器设置上这个代理服务器
Internet选项–连接—>局域网设置 localhost:8080
3)代理服务器建立好了,就可以开始建立线程组
在右边的窗口中设置线程数(相当于虚拟用户数)为50,Ramp-Up Period(in seconds,间隔时间,设为0标示并发访问)为0,,循环框中输入2。以上设置表示共有50个虚拟用户,并发访问,迭代2次
4)为线程组添加录制控制器
5)启动代理服务器。
启动代理服务器,这样在设置好代理的浏览器中访问的记录就会被记录器记录下来,并在记录器下方显示,可以查看访问的路径、参数等。
四、回放测试和结果查询
为线程组添加一个聚合报告,查看结果
取消ie代理,停止代理。
运行启动 即可在聚合报告中看到压力测试的数据。
Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值
#Samples:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,也可以以Transaction 为单位显示平均响应时间
Median:中位数,也就是 50% 用户的响应时间
90% Line:90% 用户的响应时间
Min:最小响应时间
Max:最大响应时间
Error%:本次测试中出现错误的请求的数量/请求的总数
Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 的 Transaction per Second 数
KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec
添加代理服务器后出现问题:连接到localhost 提示:位于 XDB 的服务器 localhost 要求用户名和密码,出现此问题的原因是由于安装oralce造成的。Oracle 9i创建数据库时默认包含了XDB特性。一旦启动了数据库和Listener,Oracle XDB启动http服务。XDB的http服务就占用8080端口,刚好和JBoss、Tomcat等默认端口冲突,Oracle XDB的端口设置不在配置文件中,而是在数据库里。这就是主要原因,当然还有可能是其它的原因。
解决方法如下:
1,打开services.msc,将OralceServiceYourOracleSid服务器关闭,先完成测试,当需要使用oracle时再开启此服务。
2,修改XDB服务器的端口号同样可以达到目的,步骤如下
禁用Oracle的XDB服务的方法很简单,去掉相应的数据库的初始化参数即可:
编辑$ORACLE_HOME/dbs/initSID.ora文件,去除如下行:
dispatchers=’(PROTOCOL=TCP) (SERVICE=XDB)’
重启数据库
shutdown immediate;
create spfile from pfile;
startup;
修改XDB服务端口:
XDB的http服务就占用8080端口,刚好和JBoss、Tomcat等默认端口冲突,Oracle XDB的端口设置不在配置文件中,而是在数据库里。如下修改XDB的http和ftp服务端口:
使用sys登录sqlplus,利用dbms_xdb修改端口设置
SQL> — Change the HTTP/WEBDAV port from 8080 to 8081
SQL> call dbms_xdb.cfg_update(updateXML(
2 dbms_xdb.cfg_get()
3 , ‘/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text()’
4 , 8081))
5 /
Call completed.
SQL> — Change the FTP port from 2100 to 2111
SQL> call dbms_xdb.cfg_update(updateXML(
2 dbms_xdb.cfg_get()
3 , ‘/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text()’
4 , 2111))
5 /
Call completed.
SQL> COMMIT;
Commit complete.
SQL> EXEC dbms_xdb.cfg_refresh;
PL/SQL procedure successfully completed.