认识开源性能工具:JMeter
JMeter是什么:
- Apache JMeter是Apache组织开发的基于Java的压力测试工具。
- JMeter可以用于对于服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。另外,JMeter能够对应用程序做功能/回归测试,通过创建带有断言的脚本来验证你的程序返回了你期望的结果。为了最大限度的灵活性,JMeter允许使用正则表达式创建断言。
JMeter的特点:
- 能够对HTTP和FTP服务器进行压力和性能测试,也可以对任何数据进行同样的测试(通过JDBC)。
- 完全的可移植性和100%纯java。
- 完全多线程 框架允许通过多个线程并发取样和 通过单独的线程组对不同的功能同时取样。
- 各种负载统计表和可链接的计时器可供选择。
- 数据分析和可视化插件提供了很好的可扩展性以及个性化(可以自己开发插件运用到里面去)。
- 具有提供动态输入到测试的功能。
JMeter的下载和安装:
- 前置条件:安装好jdk
- JMeter下载地址:http://jmeter.apache.org/download_jmeter.cgi
- 一般启动:解压,bin目录里的jmeter.bat即可启动
- 服务器模式启动:jmeter-server.bat。允许在远程节点上以服务器模式运行jmeter,并通过jmeter gui来控制。
JMeter工作原理:
通过多线程模拟服务器访问压力
JMeter目录结构:
- bin目录是可执行文件,jmeter.bat启动,里面可以设置jvm(java虚拟机)参数。
- 根据经验,heap(堆内存)最多设置为物理内存的一半,默认设置为512M。如果heap超过物理内存的一半,可能运行jmeter会慢,甚至出现内存溢出。(java比较吃内存)
- jmerer的log在jmeter.log中查看
- jmeter.properties文件中有一个属性log_level.JMeter可以设置改变日志详细度。默认是info,可改为debug。
- docs下是JMeter的java docs。
- printable_docs(较常用)的usermanual子目录下是jmeter用户手册,其中component_reference.html是最常用的核心元件帮助手册。
- extras目录下的文件提供了对ant的支持,可以利用ant来实现自动化,例如批量执行脚本,产生html报告等。
- 运行jmeter的时候产生一个jtl文件,把他放到extras目录下,运行ant -Dtest=文件名 report就可以生成测试统计报表
- lib目录(放了一些可执行的包)下的ext子目录是jmeter的核心.jar包;junit子目录是放junit脚本的。
- 用户扩展所依赖的包直接放到lib下即可,不要放到lib/ext下。
JMeter vs LoadRunner
对比项 | JMeter | LoadRunner |
---|---|---|
安装 | 简单,下载解压即可 | 复杂,LoadRunner安装包大于1GB,在一台主频3.0、内存1GB的PC上安装,安装时间大于1h |
录制/回放模式 | 支持 | 支持 |
测试协议 | 偏少,用户可自行扩展 | 较多,用户不可自行扩展 |
分布式大规模压力测试 | 支持 | 支持 |
IP欺骗功能 | 不支持 | 支持 |
图形报表 | 支持(较弱) | 支持(很强) |
测试逻辑控制 | 支持 | 支持 |
监控服务器资源(CPU、内存等) | 支持 | 支持 |
功能测试 | 支持 | 支持(读取脚本) |