> Use Cloud
> Use multiple JMeter Instances on Multiple
Servers
> Distribute the load across Multiple Servers by
scheduling JMeter tests to kick off on all Servers @ Same Time (linux cron job)
> Combine all CSVs and Prepare Report (scp,
shell and awk)
> Use GIT to Version Control and Keep in SYNC JMeter
Scripts and Data on All Servers
> Use Cloud
Use cloud for all the benefit it brings. I use AWS
and Datapipe cloud.
> Use multiple JMeter instances and Multiple Linux
Servers
For one of my scenario, I use one JMeter instance for
every 30 concurrent threads, each JMeter instance having 512MB heap size (jmeter.bat:set
HEAP=-Xms512m -Xmx512m), I spawn 30 JMeter instances on one JMeter server (CentOS
6.4 OS, Headless JMeter) which gives me 900 concurrent threads on one linux
server. Server spec - CentOS 6.4, 16GB memory, 2.4GHz clock speed, quad core.
This is specific to my scenario. You need to do some initial tests to find out
how much load a server of this spec can support for your scenario. It is not a
standard, it depends on your scenario. Use shell script to kick off 30
instances of JMeter (in a loop)
> Distribute the load across servers by
scheduling JMeter tests to kick off on all Servers @ Same Time (cron job)
I use two JMeter
servers (in Cloud) to simulate 900 * 2 = 1800 concurrent users
I initially tried
JMeter’s distributed load feature it did not work for me. So I took a different
approach. Using linux cron job I schedule tests (on multiple servers) to kick
off at the same time. This way I can scale up the load by adding more CentOS
linux servers in cloud.
> Combine all aggregate report CSVs and Prepare
Report (scp, shell and awk)
Using scp download all the jmeter aggregate report csv
files onto your local machine. Use awk to combine and filter all the csv files
into a single aggregate csv file. This csv file can be opened in JMeter to get
a single aggregate report. It takes a while to set this up, but once done, you
can scale load by just adding more Linux servers and simply schedule tests
whenever you need. Using cloud it just takes few minutes to spin up servers and
setup jmeter.
> Use GIT
I keep all the jmeter scripts and data in a GIT
repository. This allows me to keep control on versions of JMeter scripts, data
and results and also helps to keep scripts and data in SYNC on all servers. I
just clone the repository on a new server to get all the scripts and data ready
to go.
No comments:
Post a Comment