7 min readHow to test your API for load balancing and auto scaling using Jmeter?
Saran
Saran
Api Test

API test for load balancing and auto scaling using Jmeter

Load testing is important for every application as it is essential to know how much traffic an application can take. Almost all popular applications will have enormous traffic to their websites.

It is required to check the load testing before the application is published where there are many tools to check the load testing. We use the most advanced open-source tool Apache Jmeter for load testing and load balancing. Here we are getting started with Apache Jmeter for load testing.

Prerequisites for load testing

API For Load Balancing
  1. Jmeter RUN time application
  2. JAVA/JDK
  3. Require a multi core processor system and 8 GB RAM or above systems which allows to test more concurrent users.

To download Apache jmeter and JAVA installation, visit the website http://jmeter.apache.org/ 

Download Jmeter

Check for the download releases and download the latest version based on the Operating system. Then, you can download the ZIP file available under binaries.

For Windows,  you can download 

Apache-jmeter-5.2.1.zipsha512pgp

For Apple and  Linux, download 

Apache-jmeter-5.2.1.zipsha512pgp

After downloading the latest jmeter in the system, extract the ZIP folder. Then open the Apache jmeter folder and go to the BIN directory. Click and Run jmeter batch file to launch the JMeter. Prior to that we need to install JAVA on your machine. Then, we need to go to the Oracle website to download the latest JDK to the system. Based on the OS, choose the proper JDK file system and click on download. As we have a windows system, we are downloading jdk-13.0.2_windows-x64_bin.exe  

Install Java

After downloading and installing JAVA, then it is required to setup the environment path variable for JAVA. We can set JAVA path in system settings. After JAVA is successfully installed and configured in the system, check whether it is available in your system or not. Then go to RUN and check in command prompt. Use command java -version to check java installed version.

How to Create Test Plan and Run Using Jmeter:

Here we create a sample test for signup and login for a website

Goto Apache jmeter folder → Bin → Click on Jmeter.bat file to launch the jmeter application

Create and run a test plan

First, create a new test plan. Then, create a new thread group under test plan. The test plan can have many threads based on test scenarios. Then we can check the Signup and Login users load testing on an application.

Then add HTTP request under the threadgroup. We can test both http or https requests. We just need to hit the simple Http website URL. Then, mention IP address in the server name or IP field. Then, add “listener” to see the request results and also add a listener under the thread group. It is very simple to hit the server request. Then you can click on the RUN button to run the test. Here comes our test run as successful.

Increase the load on the Website

Goto thread group configuration. 

i) Number of thread users: Define how many users or requests are accessing the URL based on the required load.

ii) Ramp-up period speed: Specify the time frame as within the given time the test has to be executed successfully.

iii) Loop Count: We can define how many times the test has to execute.

Now summarize the above configuration:

10 users in 2 seconds 2 times need to access the website. Now lets run this test. 10*2= 20 requests has to hit the website URL.

If our test summary has any errors, we saw the URL hitting with specified load. Next we are going to see the signup to the website.

How to give the load to Sign Up API?

Now pass API URL in the path Field. Reading the API response needs to give UTF-8 format. Check the post method and mention the method type. Now lets add the API parameters. Now add the parameters to signup for API. In the same way, we have to add the remaining parameters. Here use the dynamic parameters. We have user-defined variables to send unique email and phone numbers. Add the user-defined variables.

This is the detailed process of how to successfully test API using Jmeter.

Amazon EC2 scaling and how load is shared in between the server instances.

Here, we give more load to the application and check using the Amazon EC2 scaling. When we give maximum load to the application the amazon EC2 creates replica instances and balance the load on the server.

How to check load and instance creation?

Here we check 4000 concurrent users login into the website and use the autoscaling of EC2. Here we can check the DB auto scaling based on load.

Amazon gives these features to protect and give steadiness to the application when there is heavy traffic to the application.

Let’s have a look at the demo:

Check the login API and need to pass valid parameters. We can pass the dynamic user credentials to test the load or else we can give static user credentials test load with the same user. 

The same user details will be reused and created as virtual users based thread users. Since we have some restrictions running Jmeter in GUI Mode. We will run the test in Non GUI mode which will reduce the load on the system and the test will run smoothly.

Finally the script is saved, lets run the test. Let’s login to the amazon console and monitor the EC2 scaling and DB auto scaling. We can observe that the new instances will be created and new DB replicas will be created. Sign in to amazon console. Now lets run the test in Non GUI

The file is saved on the desktop and navigate the jmeter folder path, after that we need to input the jmeter run command.

jmeter -n -t test file path (.jmx file)

Then enter to run the test script. Based on the load, the tasks are created.

By default it will be one task. Based on load it will create new instances. Transfer/share the load with new instances. The containers are increased from 1 to 3. Let’s check the DB replicas. By default, we have one write DB and one read DB. Based on connections and load to DB the read replicas will be created and used. You can see the 3 read replicas are created.

See our test has completed with 0 errors.

Here, the application has handled 4000 user login successfully.

Saran

Saran

Digital transformation expert with 12 years of experience in digital products for various industries.

https://nextbrain.ca

GET IN TOUCH

  • Canada+1
  • Afghanistan (‫افغانستان‬‎)+93
  • Albania (Shqipëri)+355
  • Algeria (‫الجزائر‬‎)+213
  • American Samoa+1684
  • Andorra+376
  • Angola+244
  • Anguilla+1264
  • Antigua and Barbuda+1268
  • Argentina+54
  • Armenia (Հայաստան)+374
  • Aruba+297
  • Australia+61
  • Austria (Österreich)+43
  • Azerbaijan (Azərbaycan)+994
  • Bahamas+1242
  • Bahrain (‫البحرين‬‎)+973
  • Bangladesh (বাংলাদেশ)+880
  • Barbados+1246
  • Belarus (Беларусь)+375
  • Belgium (België)+32
  • Belize+501
  • Benin (Bénin)+229
  • Bermuda+1441
  • Bhutan (འབྲུག)+975
  • Bolivia+591
  • Bosnia and Herzegovina (Босна и Херцеговина)+387
  • Botswana+267
  • Brazil (Brasil)+55
  • British Indian Ocean Territory+246
  • British Virgin Islands+1284
  • Brunei+673
  • Bulgaria (България)+359
  • Burkina Faso+226
  • Burundi (Uburundi)+257
  • Cambodia (កម្ពុជា)+855
  • Cameroon (Cameroun)+237
  • Canada+1
  • Cape Verde (Kabu Verdi)+238
  • Caribbean Netherlands+599
  • Cayman Islands+1345
  • Central African Republic (République centrafricaine)+236
  • Chad (Tchad)+235
  • Chile+56
  • China (中国)+86
  • Christmas Island+61
  • Cocos (Keeling) Islands+61
  • Colombia+57
  • Comoros (‫جزر القمر‬‎)+269
  • Congo (DRC) (Jamhuri ya Kidemokrasia ya Kongo)+243
  • Congo (Republic) (Congo-Brazzaville)+242
  • Cook Islands+682
  • Costa Rica+506
  • Côte d’Ivoire+225
  • Croatia (Hrvatska)+385
  • Cuba+53
  • Curaçao+599
  • Cyprus (Κύπρος)+357
  • Czech Republic (Česká republika)+420
  • Denmark (Danmark)+45
  • Djibouti+253
  • Dominica+1767
  • Dominican Republic (República Dominicana)+1
  • Ecuador+593
  • Egypt (‫مصر‬‎)+20
  • El Salvador+503
  • Equatorial Guinea (Guinea Ecuatorial)+240
  • Eritrea+291
  • Estonia (Eesti)+372
  • Ethiopia+251
  • Falkland Islands (Islas Malvinas)+500
  • Faroe Islands (Føroyar)+298
  • Fiji+679
  • Finland (Suomi)+358
  • France+33
  • French Guiana (Guyane française)+594
  • French Polynesia (Polynésie française)+689
  • Gabon+241
  • Gambia+220
  • Georgia (საქართველო)+995
  • Germany (Deutschland)+49
  • Ghana (Gaana)+233
  • Gibraltar+350
  • Greece (Ελλάδα)+30
  • Greenland (Kalaallit Nunaat)+299
  • Grenada+1473
  • Guadeloupe+590
  • Guam+1671
  • Guatemala+502
  • Guernsey+44
  • Guinea (Guinée)+224
  • Guinea-Bissau (Guiné Bissau)+245
  • Guyana+592
  • Haiti+509
  • Honduras+504
  • Hong Kong (香港)+852
  • Hungary (Magyarország)+36
  • Iceland (Ísland)+354
  • India (भारत)+91
  • Indonesia+62
  • Iran (‫ایران‬‎)+98
  • Iraq (‫العراق‬‎)+964
  • Ireland+353
  • Isle of Man+44
  • Israel (‫ישראל‬‎)+972
  • Italy (Italia)+39
  • Jamaica+1876
  • Japan (日本)+81
  • Jersey+44
  • Jordan (‫الأردن‬‎)+962
  • Kazakhstan (Казахстан)+7
  • Kenya+254
  • Kiribati+686
  • Kosovo+383
  • Kuwait (‫الكويت‬‎)+965
  • Kyrgyzstan (Кыргызстан)+996
  • Laos (ລາວ)+856
  • Latvia (Latvija)+371
  • Lebanon (‫لبنان‬‎)+961
  • Lesotho+266
  • Liberia+231
  • Libya (‫ليبيا‬‎)+218
  • Liechtenstein+423
  • Lithuania (Lietuva)+370
  • Luxembourg+352
  • Macau (澳門)+853
  • Macedonia (FYROM) (Македонија)+389
  • Madagascar (Madagasikara)+261
  • Malawi+265
  • Malaysia+60
  • Maldives+960
  • Mali+223
  • Malta+356
  • Marshall Islands+692
  • Martinique+596
  • Mauritania (‫موريتانيا‬‎)+222
  • Mauritius (Moris)+230
  • Mayotte+262
  • Mexico (México)+52
  • Micronesia+691
  • Moldova (Republica Moldova)+373
  • Monaco+377
  • Mongolia (Монгол)+976
  • Montenegro (Crna Gora)+382
  • Montserrat+1664
  • Morocco (‫المغرب‬‎)+212
  • Mozambique (Moçambique)+258
  • Myanmar (Burma) (မြန်မာ)+95
  • Namibia (Namibië)+264
  • Nauru+674
  • Nepal (नेपाल)+977
  • Netherlands (Nederland)+31
  • New Caledonia (Nouvelle-Calédonie)+687
  • New Zealand+64
  • Nicaragua+505
  • Niger (Nijar)+227
  • Nigeria+234
  • Niue+683
  • Norfolk Island+672
  • North Korea (조선 민주주의 인민 공화국)+850
  • Northern Mariana Islands+1670
  • Norway (Norge)+47
  • Oman (‫عُمان‬‎)+968
  • Pakistan (‫پاکستان‬‎)+92
  • Palau+680
  • Palestine (‫فلسطين‬‎)+970
  • Panama (Panamá)+507
  • Papua New Guinea+675
  • Paraguay+595
  • Peru (Perú)+51
  • Philippines+63
  • Poland (Polska)+48
  • Portugal+351
  • Puerto Rico+1
  • Qatar (‫قطر‬‎)+974
  • Réunion (La Réunion)+262
  • Romania (România)+40
  • Russia (Россия)+7
  • Rwanda+250
  • Saint Barthélemy+590
  • Saint Helena+290
  • Saint Kitts and Nevis+1869
  • Saint Lucia+1758
  • Saint Martin (Saint-Martin (partie française))+590
  • Saint Pierre and Miquelon (Saint-Pierre-et-Miquelon)+508
  • Saint Vincent and the Grenadines+1784
  • Samoa+685
  • San Marino+378
  • São Tomé and Príncipe (São Tomé e Príncipe)+239
  • Saudi Arabia (‫المملكة العربية السعودية‬‎)+966
  • Senegal (Sénégal)+221
  • Serbia (Србија)+381
  • Seychelles+248
  • Sierra Leone+232
  • Singapore+65
  • Sint Maarten+1721
  • Slovakia (Slovensko)+421
  • Slovenia (Slovenija)+386
  • Solomon Islands+677
  • Somalia (Soomaaliya)+252
  • South Africa+27
  • South Korea (대한민국)+82
  • South Sudan (‫جنوب السودان‬‎)+211
  • Spain (España)+34
  • Sri Lanka (ශ්‍රී ලංකාව)+94
  • Sudan (‫السودان‬‎)+249
  • Suriname+597
  • Svalbard and Jan Mayen+47
  • Swaziland+268
  • Sweden (Sverige)+46
  • Switzerland (Schweiz)+41
  • Syria (‫سوريا‬‎)+963
  • Taiwan (台灣)+886
  • Tajikistan+992
  • Tanzania+255
  • Thailand (ไทย)+66
  • Timor-Leste+670
  • Togo+228
  • Tokelau+690
  • Tonga+676
  • Trinidad and Tobago+1868
  • Tunisia (‫تونس‬‎)+216
  • Turkey (Türkiye)+90
  • Turkmenistan+993
  • Turks and Caicos Islands+1649
  • Tuvalu+688
  • U.S. Virgin Islands+1340
  • Uganda+256
  • Ukraine (Україна)+380
  • United Arab Emirates (‫الإمارات العربية المتحدة‬‎)+971
  • United Kingdom+44
  • United States+1
  • Uruguay+598
  • Uzbekistan (Oʻzbekiston)+998
  • Vanuatu+678
  • Vatican City (Città del Vaticano)+39
  • Venezuela+58
  • Vietnam (Việt Nam)+84
  • Wallis and Futuna (Wallis-et-Futuna)+681
  • Western Sahara (‫الصحراء الغربية‬‎)+212
  • Yemen (‫اليمن‬‎)+967
  • Zambia+260
  • Zimbabwe+263
  • Åland Islands+358