locust.io is an easy to use, scriptable and scalable open source load and performance testing tool. The Azure Mission-Critical reference implementation leverages Locust as a standalone load testing tool only. A separate pipeline is used to spin up a Locust deployment with a WebUI to conduct customized load tests on-demand.
The standalone deployment consists of a single master node and one or more worker nodes, the number can be configured at pipeline execution time, distributed across multiple Azure regions. The worker nodes execute the load testing tasks and communicate with the master node on port 5557/TCP
. The master node is orchestrating the worker nodes, gathering the load test data and (in standalone-mode only) hosting a web interface on port 8089/TCP
to conduct and monitor load tests.
All nodes are represented as individual container instances, hosted on Azure Container Instances (ACI) and are deployed via Terraform. The Terraform definition is stored in the src/infra/loadtest-locust
directory.
The standalone environment can be scaled-up and down via the Azure.AlwaysOn Deploy Locust (standalone) pipeline in Azure DevOps. The number of worker nodes can be defined for each individual pipeline run:
To scale the infrastructure down you can simply execute the pipeline with "Number of Worker Nodes" set to zero. Setting the number of workers to 0
will tear down all workers and will remove the master node as well.
Further configuration changes can by done by modifying the variables.tf
file. Here are the most relevant configuration options:
locust_worker_locations
is a list of datacenter regions the workers will be spread acrosslocust_version
contains the locust image and tag e.g.locustio/locust:2.2.2
The additional infrastructure consisting of an Azure Storage Account hosting the locustfile.py
test definition as well as an Azure Key Vault hosting the randomly generated password used to access the locust web interface. Those two resources will remain, even if the Locust workers are scaled down to zero.
Check out Globally distributed load tests in Azure with Locust to learn more about Locust on ACI.
The embedded version is deprecated and was removed in a previous release.
The embedded version of Locust is "embedded" into the Azure.AlwaysOn E2E Release pipeline and can be enabled by selecting "Run embedded load testing" when running the pipeline.
This results in an additional pipeline stage:
And uploads the load test results at the end at the end of each successful run as pipeline artifacts:
Some of the REST methods on the Azure Mission-Critical sample workload API are protected with API key-based authentication. In order to call the API and run tests, Locust needs to present the X-API-Key: XXX
HTTP header. The corresponding value can be fetched from of of the Azure Key Vault of the deployment (it is the same key between all the stamps).
All tests are defined in the locustfile.py
Python file. They're defined as a sequence of API calls which represent typical user actions in the application.
Locust supports weight specification on individual tasks, so the test is configured in a way that sending new ratings is more frequent than typing text-based comments, to reflect realistic usage pattern.
The locusfile.py
Python file is automatically uploaded into the File Share of a dedicated Azure Storage Account:
From there it is mounted into the worker and master container instances:
Here an example with one master and two worker containers:
The locust web interface is only available in the Standalone-version, it is hosted by the master container instance on port 8089
. It is protected with basic web-auth, the password is randomly generated and stored in Azure Key Vault. Our pipeline will return the public DNS FQDN of our master node at the end of each successful pipeline run.
Important! To login to the locust web interface, you have to retrieve the password from Azure Key Vault. The username is always locust.
It allows you to specify a Number of total users to simulate as well as the Spawn rate (users spawned/per second).