Jmeter non-gui mode generates real time Test Results in the below format:
summary = 1649731 in 00:10:06 = 2721.2/s Avg: 47 Min: 9 Max: 16027 Err: 112 (0.01%)
summary + 63699 in 00:00:30 = 2123.3/s Avg: 64 Min: 12 Max: 2080 Err: 4 (0.01%) Active: 192 Started: 193 Finished: 1
summary = 1713430 in 00:10:36 = 2693.0/s Avg: 47 Min: 9 Max: 16027 Err: 116 (0.01%)
summary + 62509 in 00:00:30 = 2083.6/s Avg: 66 Min: 11 Max: 2034 Err: 1 (0.00%) Active: 192 Started: 193 Finished: 1
summary = 1775939 in 00:11:06 = 2665.6/s Avg: 48 Min: 9 Max: 16027 Err: 117 (0.01%)
summary + 69708 in 00:00:30 = 2323.5/s Avg: 45 Min: 9 Max: 2074 Err: 4 (0.01%) Active: 123 Started: 193 Finished: 70
summary = 1845647 in 00:11:36 = 2650.9/s Avg: 48 Min: 9 Max: 16027 Err: 121 (0.01%)
What is summary + and summary = ?
Summary + are incremental for the latest summariser period
Summary = are cumulative for the above Summary+
summary + 63699 in 00:00:30 = 2123.3/s
summary = 1713430 in 00:10:36 = 2693.0/s
Example 63699 in 00:00:30 = 2123.3/s means that in 30seconds Jmeter have sent 63699 requests to the server with an average throughput of 2123 requests per second.
The next iteration will start from the ahead of the cumulative time of the above summary. Ex: 00:11:06 = (00:00:30 + 00:10:36)
As per Top 2 Techniques to Get JMeter Test Results in non-GUI mode
Here’s an example of what you get from the default summariser:
summary + 41 in 15.4s = 2.7/s Avg: 2234 Min: 383 Max: 6974 Err: 0 (0.00%)
summary + 57 in 21.5s = 2.6/s Avg: 2548 Min: 618 Max: 4528 Err: 0 (0.00%)
summary = 98 in 32.5s = 3.0/s Avg: 2416 Min: 383 Max: 6974 Err: 0 (0.00%)
summary + 108 in 21.8s = 5.0/s Avg: 1291 Min: 229 Max: 6317 Err: 0 (0.00%)
summary = 206 in 52.5s = 3.9/s Avg: 1827 Min: 229 Max: 6974 Err: 0 (0.00%)
The lines with summary + are incremental for the latest summariser period, the lines with summary = are cumulative. The above was with a summariser period of 20 secs, the actual periods can sometimes be longer than the specified period and the length of the very first period is somewhat random. You get the throughput statistics as well as average, min and max response times, and how many errors were detected (assuming your JMeter test plan has assertions to detect errors).
If the JMeter's summariser output doesn't seem too informative to you consider running your JMeter test using Taurus tool as a wrapper, it has console reporter which prints current metrics right in your terminal:
You can also configure Backend Listener to store results to InfluxDB and plot them using Grafana, an example dashboard can look like:
Related
when I am load testing for 100 users at rampup of 2 seconds I am getting different values for same users and same ramp up time why is this happening can anyone help?
in remote server
1st time
summary = 100 in 00:00:03 = 31.7/s Avg: 1916 Min: 985 Max: 2737 Err: 0 (0.00%)
2nd time
summary + 1 in 00:00:01 = 1.5/s Avg: 260 Min: 260 Max: 260 Err: 0 (0.00%) Active: 22 Started: 22 Finished: 0
summary + 99 in 00:00:02 = 65.6/s Avg: 113 Min: 18 Max: 371 Err: 0 (0.00%) Active: 0 Started: 100 Finished: 100
summary = 100 in 00:00:02 = 45.9/s Avg: 114 Min: 18 Max: 371 Err: 0 (0.00%)
3rd time
summary + 1 in 00:00:01 = 2.0/s Avg: 92 Min: 92 Max: 92 Err: 0 (0.00%) Active: 14 Started: 14 Finished: 0
summary + 99 in 00:00:02 = 58.7/s Avg: 26 Min: 13 Max: 92 Err: 0 (0.00%) Active: 0 Started: 100 Finished: 100
summary = 100 in 00:00:02 = 45.5/s Avg: 26 Min: 13 Max: 92 Err: 0 (0.00%)
Normally tests should be repeatable which means that re-running the test should produce the same results.
Your test case is kind of specific, it looks like a spike test, for the first time response times are quite high and 2nd and 3rd execution they're going down. I can think of the following possible reasons:
First time response times are high because caches are not warmed up
Your application might have some optimization mechanisms like JIT
If you run exactly the same test it might be the case your system under test caches responses in different levels (operating system memory, database query cache, 3rd-party solutions like memcached
In order to have more repeatable results and better picture I would suggest:
increasing your test duration to i.e. 10 minutes
increasing your load gradually, i.e. change ramp-up time to 5 minutes
implementing monitoring of the system under test using i.e. JMeter PerfMon Plugin
Has anybody already worked with the zalopay-oss/jmeter-grpc-plugin / Apache License 2.0 GRPC Sampler for JMeter?
The following problem occurs while testing e.g. 100 quick requests which lead to 2MB payload size per response. I have no idea how to solve it. The more data was send the earlier the issue occurs.
Warning: Nashorn engine is planned to be removed from a future JDK release
Generate Summary Results + 50 in 00:00:11 = 4.6/s Avg: 188 Min: 129 Max: 1435 Err: 0 (0.00%) Active: 1 Started: 1 Finished: 0
Generate Summary Results + 50 in 00:00:08 = 6.6/s Avg: 148 Min: 127 Max: 227 Err: 0 (0.00%) Active: 0 Started: 1 Finished: 1
Generate Summary Results = 100 in 00:00:18 = 5.4/s Avg: 168 Min: 127 Max: 1435 Err: 0 (0.00%)
Generate Summary Results + 1 in 00:00:01 = 0.7/s Avg: 1043 Min: 1043 Max: 1043 Err: 0 (0.00%) Active: 1 Started: 1 Finished: 0
java.lang.OutOfMemoryError: Java heap space
Dumping heap to java_pid10268.hprof ...
Heap dump file created [1085958721 bytes in 2.412 secs]
Uncaught Exception java.lang.OutOfMemoryError: Java heap space in thread Thread[AWT-EventQueue-0,6,main]. See log file for details.
Generate Summary Results + 40 in 00:00:30 = 1.3/s Avg: 719 Min: 507 Max: 2895 Err: 0 (0.00%) Active: 1 Started: 1 Finished: 0
Generate Summary Results = 41 in 00:00:32 = 1.3/s Avg: 727 Min: 507 Max: 2895 Err: 0 (0.00%)
Generate Summary Results + 41 in 00:00:30 = 1.4/s Avg: 681 Min: 505 Max: 1156 Err: 0 (0.00%) Active: 1 Started: 1 Finished: 0
Generate Summary Results = 82 in 00:01:02 = 1.3/s Avg: 704 Min: 505 Max: 2895 Err: 0 (0.00%)
Generate Summary Results + 18 in 00:00:12 = 1.5/s Avg: 622 Min: 494 Max: 828 Err: 0 (0.00%) Active: 0 Started: 1 Finished: 1
Generate Summary Results = 100 in 00:01:14 = 1.4/s Avg: 689 Min: 494 Max: 2895 Err: 0 (0.00%)
Java heap space OOM error means that JVM isn't able to fit all the necessary objects within the define Java Heap space, default setting for the latest JMeter is 1 GB
If the default setting is not enough you can increase heap like:
Windows
set HEAP="-Xms2g -Xmx2g -XX:MaxMetaspaceSize=256m" && jmeter.bat
Unix and derivaties:
HEAP="-Xms1g -Xmx2g -XX:MaxMetaspaceSize=256m" && export HEAP && ./jmeter.sh
to make the changes permanent edit jmeter.bat or jmeter shell startup script wrappers
The above setting will increase the maximum heap size allocation twice (up to 2 GB), it may or may not be sufficient for your scenario, check whether it works and amend if necessary, just make sure that garbage collection doesn't occur to often and doesn't take too much time blocking other threads.
More information: 9 Easy Solutions for a JMeter Load Test “Out of Memory” Failure
Also looking at AWT-EventQueue it seems that you're using JMeter GUI for running the test, if it's the case - please don't, JMeter GUI is for tests development and debugging, tests are supposed to be run in command-line non-GUI mode
I have a test case with just one HTTP request. The number of threads and Ramp Up period is set to 30. And i planning to do the test for 600 seconds.
But looking at the JMeter output, i could see a huge number of requests generated. Why is this so? I am expecting only 60 threads in a minute to generate. Can someone suggest me how to do this?
S:\roshTests\apache-jmeter-3.1\bin>jmeter -n -t
S:\roshTests\LivePerformance\June1\PPS-Proxy\catalog\catalog.jmx -l
S:\roshTests\LivePerformance\June1\PPS-Proxy\catalog\Output\results.csv
Writing log file to: S:\roshTests\apache-jmeter-3.1\bin\jmeter.log
Creating summariser <summary>
Created the tree successfully using S:\roshTests\LivePerformance\June1\PPS-Proxy\catalog\catalog.jmx
Starting the test # Fri Jun 02 05:18:04 IDT 2017 (1496369884546)
Waiting for possible Shutdown/StopTestNow/Heapdump message on port 4445
summary + 377 in 00:00:25 = 15.3/s Avg: 766 Min: 106 Max: 3114 Err: 198 (52.52%) Active: 25 Started: 25 Finished: 0
summary + 1364 in 00:00:30 = 45.5/s Avg: 647 Min: 144 Max: 4385 Err: 1180 (86.51%) Active: 30 Started: 30 Finished: 0
summary = 1741 in 00:00:55 = 31.9/s Avg: 673 Min: 106 Max: 4385 Err: 1378 (79.15%)
summary + 985 in 00:00:30 = 32.8/s Avg: 643 Min: 88 Max: 4918 Err: 752 (76.35%) Active: 30 Started: 30 Finished: 0
summary = 12859 in 00:05:25 = 39.6/s Avg: 616 Min: 88 Max: 6149 Err: 10562 (82.14%)
summary + 984 in 00:00:30 = 32.8/s Avg: 675 Min: 113 Max: 5070 Err: 762 (77.44%) Active: 30 Started: 30 Finished: 0
summary = 11874 in 00:04:55 = 40.3/s Avg: 614 Min: 100 Max: 6149 Err: 9810 (82.62%)
summary + 1103 in 00:00:30 = 36.7/s Avg: 624 Min: 104 Max: 4935 Err: 884 (80.15%) Active: 30 Started: 30 Finished: 0
summary = 10890 in 00:04:25 = 41.2/s Avg: 609 Min: 100 Max: 6149 Err: 9048 (83.09%)
summary + 1220 in 00:00:30 = 40.6/s Avg: 584 Min: 100 Max: 6149 Err: 1001 (82.05%) Active: 30 Started: 30 Finished: 0
summary = 9787 in 00:03:55 = 41.7/s Avg: 607 Min: 100 Max: 6149 Err: 8164 (83.42%)
summary + 1336 in 00:00:30 = 44.5/s Avg: 570 Min: 106 Max: 5296 Err: 1106 (82.78%) Active: 30 Started: 30 Finished: 0
summary = 8567 in 00:03:25 = 41.9/s Avg: 610 Min: 106 Max: 5643 Err: 7163 (83.61%)
summary + 1320 in 00:00:30 = 44.0/s Avg: 587 Min: 116 Max: 5187 Err: 1111 (84.17%) Active: 30 Started: 30 Finished: 0
summary = 7231 in 00:02:55 = 41.4/s Avg: 618 Min: 106 Max: 5643 Err: 6057 (83.76%)
summary + 1273 in 00:00:30 = 42.5/s Avg: 637 Min: 106 Max: 5383 Err: 1072 (84.21%) Active: 30 Started: 30 Finished: 0
summary = 5911 in 00:02:25 = 40.9/s Avg: 625 Min: 106 Max: 5643 Err: 4946 (83.67%)
summary + 1430 in 00:00:30 = 47.6/s Avg: 591 Min: 116 Max: 5643 Err: 1229 (85.94%) Active: 30 Started: 30 Finished: 0
summary = 4638 in 00:01:55 = 40.5/s Avg: 621 Min: 106 Max: 5643 Err: 3874 (83.53%)
summary + 1467 in 00:00:30 = 48.9/s Avg: 589 Min: 119 Max: 4691 Err: 1267 (86.37%) Active: 30 Started: 30 Finished: 0
summary = 3208 in 00:01:25 = 37.9/s Avg: 635 Min: 106 Max: 4691 Err: 2645 (82.45%)
summary + 1070 in 00:00:30 = 35.7/s Avg: 651 Min: 99 Max: 7324 Err: 862 (80.56%) Active: 30 Started: 30 Finished: 0
summary = 13929 in 00:05:55 = 39.3/s Avg: 619 Min: 88 Max: 7324 Err: 11424 (82.02%)
summary + 1531 in 00:00:30 = 51.1/s Avg: 594 Min: 106 Max: 5194 Err: 1332 (87.00%) Active: 30 Started: 30 Finished: 0
summary = 15460 in 00:06:25 = 40.2/s Avg: 617 Min: 88 Max: 7324 Err: 12756 (82.51%)
I'm not sure if you understand the difference between Threads and requests. amount of Threads isn't equal to requests, what you're seeing in the output is the amount of requests made by your threads, and depending on your response times it's very well possible to get that many results.
Try setting the Loop count to 1 or 2 and you'll see that the requests will even out with your calculations.
Beside that... in your output on the far right side you can see how many Threads are started.
With your current setup, threads will start with one second delay.
Ramp up period is the time in which all treads should start.
You have loop set to infinite, so when all thread login after initial 30 seconds, you will always have 30 active users, and could never have more that that.
You have many more requests, depending on response time of your server, but threads are like users. If you set 30, it will always be 30. :-)
You are running 30 virtual users for 10 minutes. Each virtual user is executing samplers as fast as it can (the speed mostly depends on your application response time) this is why you have a lot of requests.
If you need to limit JMeter throughput to 60 requests per second only you can do it using Constant Throughput Timer:
Add Constant Throughput Timer to your Test Plan
Set "Target Troughput" to 60
Set "Calculate Troughput based on" to All active threads
This way JMeter will "pause" its threads (virtual users) to slow them down to 60 requests per minute.
Sometimes the summary didn't get update while executing JMeter script in Non GUI Mode, Please find below data.
Starting the test # Wed Jan 04 18:41:18 IST 2017 (1483535478893)
Waiting for possible Shutdown/StopTestNow/Heapdump message on port 4445
summary + 28 in 00:00:11 = 2.5/s Avg: 3376 Min: 1991 Max: 7555 Err: 0 (0.00%) Active: 37 Started: 37 Finished: 0
summary + 192 in 00:00:30 = 6.4/s Avg: 5623 Min: 812 Max: 19523 Err: 0 (0.00%) Active: 137 Started: 137 Finished: 0
summary = 220 in 00:00:41 = 5.4/s Avg: 5337 Min: 812 Max: 19523 Err: 0 (0.00%)
summary + 196 in 00:00:30 = 6.6/s Avg: 9388 Min: 813 Max: 46485 Err: 1 (0.51%) Active: 200 Started: 200 Finished: 0
summary = 416 in 00:01:11 = 5.9/s Avg: 7246 Min: 812 Max: 46485 Err: 1 (0.24%)
summary + 159 in 00:00:31 = 5.2/s Avg: 11175 Min: 796 Max: 79142 Err: 0 (0.00%) Active: 200 Started: 200 Finished: 0
summary = 575 in 00:01:42 = 5.6/s Avg: 8332 Min: 796 Max: 79142 Err: 1 (0.17%)
summary + 50 in 00:00:29 = 1.7/s Avg: 39434 Min: 820 Max: 108309 Err: 1 (2.00%) Active: 200 Started: 200 Finished: 0
summary = 625 in 00:02:11 = 4.8/s Avg: 10820 Min: 796 Max: 108309 Err: 2 (0.32%)
summary + 104 in 00:00:30 = 3.5/s Avg: 44422 Min: 846 Max: 125336 Err: 0 (0.00%) Active: 196 Started: 200 Finished: 4
summary = 729 in 00:02:41 = 4.5/s Avg: 15614 Min: 796 Max: 125336 Err: 2 (0.27%)
summary + 189 in 00:00:30 = 6.3/s Avg: 37163 Min: 5912 Max: 168988 Err: 0 (0.00%) Active: 172 Started: 200 Finished: 28
summary = 918 in 00:03:11 = 4.8/s Avg: 20051 Min: 796 Max: 168988 Err: 2 (0.22%)
summary + 208 in 00:00:30 = 6.9/s Avg: 27117 Min: 5369 Max: 180636 Err: 0 (0.00%) Active: 132 Started: 200 Finished: 68
summary = 1126 in 00:03:41 = 5.1/s Avg: 21356 Min: 796 Max: 180636 Err: 2 (0.18%)
summary + 232 in 00:00:30 = 7.7/s Avg: 34571 Min: 4706 Max: 220724 Err: 0 (0.00%) Active: 65 Started: 200 Finished: 135
summary = 1358 in 00:04:11 = 5.4/s Avg: 23614 Min: 796 Max: 220724 Err: 2 (0.15%)
summary + 171 in 00:00:30 = 5.7/s Avg: 21823 Min: 4524 Max: 220385 Err: 0 (0.00%) Active: 22 Started: 200 Finished: 178
summary = 1529 in 00:04:41 = 5.4/s Avg: 23413 Min: 796 Max: 220724 Err: 2 (0.13%)
The output is not shown after the last line, I wait up to 45 Min but logs are not getting updated.
Few hints:
Check jmeter.log file for anything suspicious
Get thread dump using jstack or pressing Win + Break (on Windows) and check threads statuses, see if there are any deadlocked or looping processes
Use VisualVM to attach to the process and inspect heap, see garbage collections, etc.
Check if anything is being added to .jtl results file
Most probably your JMeter instance isn't properly configured in terms of Java Heap size, Garbage Collection mode or your test plan has some issues.
References:
Troubleshooting Hanging or Looping Processes
9 Easy Solutions for a JMeter Load Test “Out of Memory” Failure
I have run jmeter script for 1500 users. It starts sending request but after some time it get stops with out showing any progress. Also test doesn't stop at end time.
Non-GUI mode console status is as follows:
summary + 280 in 112s = 2.5/s Avg: 45551 Min: 42988 Max: 84385 Err: 278 (99.29%) Active: 450 Started: 1500 Finished: 1050
summary = 14812 in 1439s = 10.3/s Avg: 77248 Min: 682 Max: 168072 Err: 12806 (86.46%)
summary + 239 in 114s = 2.1/s Avg: 47256 Min: 38723 Max: 88772 Err: 236 (98.74%) Active: 440 Started: 1500 Finished: 1060
summary = 15051 in 1469s = 10.2/s Avg: 76771 Min: 682 Max: 168072 Err: 13042 (86.65%)
summary + 264 in 115s = 2.3/s Avg: 48766 Min: 40408 Max: 87471 Err: 263 (99.62%) Active: 430 Started: 1500 Finished: 1070
summary = 15315 in 1499s = 10.2/s Avg: 76289 Min: 682 Max: 168072 Err: 13305 (86.88%)
summary + 111 in 111s = 1.0/s Avg: 55518 Min: 40488 Max: 98316 Err: 108 (97.30%) Active: 422 Started: 1500 Finished: 1078
summary = 15426 in 1530s = 10.1/s Avg: 76139 Min: 682 Max: 168072 Err: 13413 (86.95%)
summary + 163 in 129s = 1.3/s Avg: 72461 Min: 58026 Max: 111970 Err: 159 (97.55%) Active: 405 Started: 1500 Finished: 1095
summary = 15589 in 1559s = 10.0/s Avg: 76101 Min: 682 Max: 168072 Err: 13572 (87.06%)
summary + 113 in 141s = 0.8/s Avg: 78260 Min: 69917 Max: 118153 Err: 112 (99.12%) Active: 386 Started: 1500 Finished: 1114
summary = 15702 in 1590s = 9.9/s Avg: 76116 Min: 682 Max: 168072 Err: 13684 (87.15%)
summary + 104 in 159s = 0.7/s Avg: 93311 Min: 85408 Max: 146444 Err: 99 (95.19%) Active: 350 Started: 1500 Finished: 1150
summary = 15806 in 1620s = 9.8/s Avg: 76229 Min: 682 Max: 168072 Err: 13783 (87.20%)
summary + 151 in 173s = 0.9/s Avg: 91366 Min: 85043 Max: 159224 Err: 147 (97.35%) Active: 306 Started: 1500 Finished: 1194
summary = 15957 in 1650s = 9.7/s Avg: 76373 Min: 682 Max: 168072 Err: 13930 (87.30%)
summary + 178 in 186s = 1.0/s Avg: 84192 Min: 56634 Max: 165018 Err: 165 (92.70%) Active: 227 Started: 1500 Finished: 1273
summary = 16135 in 1679s = 9.6/s Avg: 76459 Min: 682 Max: 168072 Err: 14095 (87.36%)
summary + 208 in 89s = 2.3/s Avg: 44723 Min: 25609 Max: 63280 Err: 193 (92.79%) Active: 103 Started: 1500 Finished: 1397
summary = 16343 in 1709s = 9.6/s Avg: 76055 Min: 682 Max: 168072 Err: 14288 (87.43%)
Looking into summarizer results, you're getting around 90% failures. Unlikely that it is expected. So I would recommend the following:
Check jmeter.log file for any warnings or errors
Make sure that you have disabled all listeners
Run test with fewer number of threads until errors start to occur. Examine application logs to see what the problem is. As an option you can temporarily tell JMeter to store response data for failed samples by setting jmeter.save.saveservice.response_data.on_error=true property in user.properties or jmeter.properties file.
Make sure that you're following recommendations from JMeter Performance and Tuning Tips
Monitor server and load generator (JMeter) machine health. If load generator cannot create such a load you may have to consider switching to distributed testing.