The JMeter FAQ
Table of Contents |
---|
How to do remote testing the 'proper way'?
Answer: Here are a few notes to help you on your way.
You have:
- Your application server. You shouldn't run anything on this machine that you wouldn't have running on it in your proposed or actual production environment (if you are running anything else, including JMeter, you will be adding load to the server and thus tainting your results).
- One or more machines running jmeter-server (the JMeterEngine). You want these machines to be reasonably close (network wise) to the application server. By "reasonably close" I mean on the same Ethernet segment or at least with no low speed links between them. The JMeter User Manual provides reasonable information about doing this.
- A single machine running the JMeter GUI that you use to control the machines running the JMeterEngine.
While you are developing your scripts and for only moderate levels of user testing (assuming you are "close" to the application server) you do not need to involve any JMeterEngine machines.
The reason you have these are to:
- Eliminate the impact of slow network connections when you are not "close" to the application server.
- Execute more test threads than your local machine is capable of handling.
Note that if the GUI is running multiple remote servers, it can easily become a bottle-neck, especially if a lot of listeners are being used. Remove all unnecessary listeners before running stress tests.
Running JMeter in non-GUI (batch) mode is preferable, as this uses far fewer resources. The output log files can be merged after the test run and used to create overall test statistics. (CVS files can just be appended to each other; XML output files need a bit of editting to maintain well-formedness.)
If there are several nodes running the JMeter test plan, it is a good idea to try and ensure that their clocks are synchronised, as this makes it easier to analyse the data later.
How to run JMeter test plan programatically, such as from an Ant script?
Answer: Quick answer, go here. I have permission from the author of this ant task to add it to JMeter's distribution, which I will do as soon as I have the time. (It should now be in the extras folder).
How can I do stress testing of EJBs?
Answer: You can use the UserManual Reference/JavaSampler classes to write your own class that runs your EJB's, and then JMeter will take over the threading and reporting. This, however, is not ideal. Someone needs to write a good EJB Sampler implementation for JMeter (hint, hint).
Why do HTTP 3xx redirects appear as errors ? Is there a way to make them appear as HTTP 200 OK
Answer: Quick answer: They appear as an error because 302 != 200, at least in v 1.8.1.
Long answer: try using v1.9RC1, the code in HTTPSampler seems to take into account the result code for the redirect instead of the redirect result code.
How do I parameterize my JMeter test cases?
Answer: Parameters can be set at both the Test Plan and Thread Group levels.
Wiki Markup |
---|
At the Test Plan level, parameters can be used as constants to minimize changes throughout the test plan when a server or port changes, for example. \[N.B. functions are not currently supported at Test Plan level.\] |
Within Thread Groups, the User Parameters Pre-Processor can be used to set different parameters for each simulated user.
Note: if only one user (i.e. User_1) is defined, the value will be used for all threads. Functions ARE supported here. See later FAQs for more information.
The following example parameterizes the pet category from the Java Pet Store.
- Install Petstore application on a local Tomcat server.
- Start JMeter
- Click the Add button to add the following user defined variables to the Test Plan node:
- server: localhost
- port: 8080
- protocol: http
- Add a Thread Group to the Test Plan setting:
- Number of Threads: 2
- Clear the forever checkbox
- Loop Count: 1
- Add Config Element > HTTP Cookie Manager to Thread Group
- Add Pre Processors > User Parameters to Thread Group
- Click Add User to add an additional user to the User Parameters
- Click Add Variable and set name to category, User_1 to DOGS and User_2 to FISH
- Add Sampler > HTTP Request to Thread Group with the following settings:
- Server Name or IP: ${server}
- Port Number: ${port}
- Protocol: ${protocol}
- Path: /estore/control/category
- Click the Add button to add a parameter to the request:
- Name: category_id
- Value: ${category}
- Add Listener > View Results Tree to Thread Group
- Save
- Run > Start
When you view the results in the View Results Tree, you can see the ${category} value was replaced with the value from the User Parameters. Each thread will use the category from the User Parameter setting automatically. If there are more than two threads, they will reuse the values in these settings, so the third thread would use DOGS.
How do I make parameters dynamic, reacting to the unique server responses of each test run?
Answer: You can use the Regular Expression Post Processor to extract a value from a response, and then reuse this response in another request. Looking at the previous question in this FAQ, you could extract the product id from the result and use it in the following request:
- Load Test Plan created in previous FAQ question
- Add Post Processor > Regular Expression Extractor to thread Group with following values:
- Reference Name: product
- Regular Expression:
product_id=(\w*-\w*-\w*)
- Template:
$1$
- Match No.:
0
(Setting this parameter to 0 returns a random match)
- Copy the HTTP Request we created in the previous question and paste to the thread group after the previous HTTP Request
- Change the following values:
- Path:
/estore/control/product
- Add Parameter and set name to
product_id
, value to${product
}
- Path:
- Save Test Plan
- Run > Start
When you view the results in the View Results Tree, you can see the ${product} value was replaced with the value extracted by the regular expression.
How do I pass parameters into my Test scripts? I want to be able to use the same script to test with different numbers of threads and loops, and I don't want to have to change the script each time.
*Answer:*as explained above, you can use functions and variables just about anywhere in the test plan. So if you want to pass in a value a run-time, just use the __property() function, which reads the value of a JMeter property.
In order to define the property so JMeter can read it, define it on the command line as follows:
No Format |
---|
jmeter -Jproperty_name=property_value |
For example:
No Format |
---|
jmeter -Jhost2=www.zzzyy.com -Jhost1=www.jmeter-rules.net |
These values can then be read in the test plan using:
No Format |
---|
${__property(host1) |
and
No Format |
---|
${__property(host2)} |
Note: Thread Groups are slightly different from other test elements, because their settings have to be determined before the test starts. This means that you cannot use variables defined in a User Parameters form. But the __property() function works in Thread Groups, and you can use variables defined on the Test Plan.
For example, you could define the TestPlan variable:
THREADS ${__P(threads,10)
}
and then use{{ ${THREADS}}} in the ThreadGroup test element.
Elsewhere, you can use function calls, or variable references to User Parameters (which in turn could be functions), or variable references to variables set up by functions earlier in the test. There's more than one way to do it.
Suppose you want to be able to vary the number of threads in a test plan. Choose a suitable property name, say group1.threads. Replace the thread count in the GUI (or the JMX, if you're feeling brave!) with the following function call:
No Format |
---|
${__property(group1.threads)} |
Then, when starting JMeter, define the property on the command line:
No Format |
---|
jmeter -Jgroup1.threads=12345 |
It can be useful to put default settings into the jmeter property file, so you only need to supply differences on the command line.
No Format |
---|
# defaults in jmeter.properties group1.threads=10 group1.loops=100 group1.rampup=10 |
Then just do jmeter -Jgroup1.loops=1000 for example.
Versions of JMeter after 1.9.1 have a new version of the __property() function which allows a default value to be supplied, in case the property is not found:
No Format |
---|
${__property(group2.threads,,defaultvalue)} |
There is also a shorthand version called __P(), which you can use as follows:
No Format |
---|
${__P(group2.threads,100)} |
if you omit the value, it defaults to 1
How do I use external data files to define variables in my Test scripts?
Answer: The CSV Data Set Config element is the best way to do this, as it can create multiple variables from a single data file.
Answer: Another way to do this is to create a User Parameters Pre-Processor in which you list all the values that you want to read from files. You can then use the variable names later in the script.
For example:
- Start JMeter
- Add a Thread Group to the Test Plan
- set the appropriate number of threads and iterations
- Add Pre Processors > User Parameters to Thread Group
- Click Add Variable
- Set Update once per iteration
- Set the Name to the name of the variable (e.g. ACCOUNTID)
1. Set the value (under User_1) to${_StringFromFile(accounts.dat)
}
- Add Sampler > HTTP Request to Thread Group:
- Click the Add button to add a parameter to the request:
- Name: account_id
- Value: ${ACCOUNTID}
- Add Listener > View Results Tree to Thread Group
- Save
1. create the file accounts.dat containing one line per account id. If it is not in the bin directory, then modify the String{{`From}}`File parameter accordingly, e.g. {${_StringFromFile(../testdata/accounts.dat)} or ${_StringFromFile(/home/user/testdata/accounts.dat)} or ${_StringFromFile(C:/work/data/accounts.dat)
}}
1. Run > Start
Each iteration, the ACCOUNTID variable will be set to the next line in the file, and the HTTP Request will use its value to set the account_id parameter.
When the end of the file is reached, StringFromFile starts reading again at the beginning.
N.B. If using such a script in client-server mode, make sure that any data files are copied to the appropriate place on the server host, as the files will be opened by the server process, not the client.
I'm having difficulty getting JMeter to work with SSL (HTTPS). What's the problem?
Answer: Check out the documentation item 1.2.4.
A lot of people struggle with this, either because of private certs or whatever - I'm looking for a page that details common trip-ups and solutions for them. – MikeStover
I'm having difficulty building Jmeter from NetBeans IDE. It is looking for a org.apache.log.Hierarchy, which log util is it looking for?
Answer: Make sure to mount all of the jars in the lib folder.
Has anyone out there used JMeter as part of junit testing? I'd like to think that by using assertions with a custom JUnit listener JMeter could be run in as part of functional testing.
Answer: It's a great idea to write some glue between JMeter and JUnit for just this purpose. It doesn't exist currently, though there is an Ant task for JMeter that you might find useful.
Can JMeter record HTTPS requests using the recording proxy?
Answer: Yes, in JMeter 2.4. JMeter now uses its own dummy certificate which the browser needs to be configured to accept.
How can I display the response text my assertation runs against?
Answer: You can display your server's response text in the View Results Tree listener.
Is there a JMX Schema/DTD available?
Answer: No. Don't plan on having one either at this point. Changes would be too frequent to realistically keep up with.
What happens with redirects when asserting HTTP responses?
Answer: Assertions aren't smart enough to do the right thing with redirected requests - currently the 302 response would be asserted against. You can get around this by recording your test plans and leaving "follow redirects" off.
Alternatively, the latest JMeter release (after 1.9.1) has an option to allow the redirects to be handled by the Java libary routines. Earlier versions of Java did not support redirects properly, but if you want to try, just define the following JMeter property:
No Format |
---|
HTTPSampler.delegateRedirects=true |
JMeter will then not see the redirects at all.
I've set the CLASSPATH, but JMeter is not picking up my Jars
Answer: The CLASSPATH variable is ignored when using the -jar flag. For some further information on this, see: How the Java launcher finds user classes
JMeter currently knows to look for jars/classes in two places only:
- lib/ext, where the ApacheJMeter_*.jar files live
- lib, where the 3rd party jar files live
Additional jars should normally be placed in the lib directory; however, if you have written an add-on for JMeter itself, that should be put in the lib/ext directory.
If you want your jar file to be available to all Java applications, it can be placed in the JVM extensions directory
Another possible solution is to take a copy of the jmeter startup script, and replace:
No Format |
---|
-jar ["ApacheJMeter"].jar |
with
No Format |
---|
org.apache.jmeter.NewDriver |
after adding ApacheJMeter.jar to the classpath
What Pattern matching (regexen) does JMeter support?
Answer: JMeter includes the pattern matching software Apache Jakarta ORO.
See RegularExpressions for more details and examples
I want to use “Monitor Results” of JMeter
Currently I am using WAS 5.0 Application Server . For “Monitor Results” , JMeter shows the example for TOMCAT 5.0 WebServer.
Info | ||
---|---|---|
| ||
Add the HTTP Request to the Thread Group element (Add → Sampler → HTTP Request). Then, select the HTTP Request element in the tree and edit the following properties): Change the Name field to "Server Status". Enter the IP address or Hostname Enter the port number Set the Path field to "/manager/status" if you're using Tomcat. Add a request parameter named "XML" in uppercase. Give it a value of "true" in lowercase. Check "Use as Monitor" at the bottom of the sampler |
Please let me know how I can set “Monitor Results” of JMeter in WAS5.0.
To use the JMeter Monitor for IBM WAS5.0, you will need to port the status servlet from Tomcat5 to WAS. Your other option is to write your own status servlet and output the data in the correct format. Tomcat5 includes the schema for the status data. If you have any further question, feel free to email the jmeter-user mailing list.
JMeter keeps getting "Out of Memory" errors. What can I do?
This is usually caused by including memory intensive listeners in your stress test. Listeners like "View Tree Results" are useful for debugging your test, but they are too memory intensive to remain in your test when you ramp up the number of simulated users and iterations. The best listeners to use for a long-term, high-load test are Aggregate Listener, Graph Listener, and Spline Listener.
In addition, you can instruct the JVM to use more memory by editing the jmeter/jmeter.bat files for linux/windows. Within these files, find a section that sets values for the Heap:
set HEAP=-Xms256m -Xmx256m
Feel free to change these values. Xms indicates the starting RAM the jvm will take, and Xmx will be the maximum it is allowed (for the HEAP).
Does JMeter process dynamic pages (e.g. Javascript and applets)
No. JMeter does not process Javascript or applets embedded in HTML pages.
JMeter can download the relevant resources (some embedded resources are downloaded automatically if the correct options are set), but it does not process the HTML and execute any Javascript functions.
If the page uses Javascript to build up a URL or submit a form, you can use the Proxy Recording facility to create the necessary sampler. If this is not possible, then manual inspection of the code may be needed to determine what the Javascript is doing.
What about backward compatibility ?
Answer: JMeter 2.1 uses a new format. But you can set values to 2.0 to save to old format.
You should take a look at jmeter.properties in your bin directory.
You can uncomment those lines (remove # character) and restart jmeter :
No Format |
---|
# Save test plans and test logs in 2.0 format #file_format=2.0 # Just test plans (jmx) #file_format.testplan=2.0 # Just test logs (jtl) #file_format.testlog=2.0 |
You can also take a look at this mail archive from dev list.
More informations about: JmxTestPlan or JtlTestLog
How do I ensure each http request for jsp is within one jsessionid ?
Just insert an HTTP Cookie Manager. This keeps track of all cookies for each thread within the thread group. Without http cookie manager, each request is a new session as cookies are not kept. jsessionid is only shown for the very first request, subsequent request will not see the jsessionid. to use a variable in jmeter is ${name of variable}.
This is very useful when dealing with jsp form logins, as the first request is to login to the system and subsequent request is to do load testing on the target page. This will prevent redirection back into login page.
How do I ensure the remote jmeter server can communicate with the master client?
Sometimes java/rmi doesn't determine the correct IP address of your client. For example if you are communicating over a vpn under linux, the ppp interface is the IP that you want to use, but java may end up using the eth1 interface. If this is the case, you will see a connect exception in the jmeter-server log, which will mention an IP address different than the one you want it to use. You can force rmi to use a different IP address than the one it looks up by setting a system property: -Djava.rmi.server.hostname=192.168.5.6