Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Lingaro/azure-locust
Distributed load tests on Azure
https://github.com/Lingaro/azure-locust
Last synced: 2 months ago
JSON representation
Distributed load tests on Azure
- Host: GitHub
- URL: https://github.com/Lingaro/azure-locust
- Owner: Lingaro
- License: mit
- Created: 2020-01-09T08:11:39.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-06-09T07:18:17.000Z (over 1 year ago)
- Last Synced: 2024-08-04T02:07:53.904Z (6 months ago)
- Language: Python
- Size: 2.07 MB
- Stars: 30
- Watchers: 6
- Forks: 17
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
- awesome-locust - azure-locust - Run distributed Locust load tests on Azure Container Instances. (Tools / Distributed)
README
# Azure Locust
Run distributed [Locust](https://locust.io/) load tests on _Azure Container Instances_. It's quick, cheap and scalable! Using 20 slaves you can achieve ~12 000 req/s!
![Locust Diagram](docs/locust-diagram.png)
You can deploy and manage resources using either:
* [Azure Portal](https://portal.azure.com) - easier
* [Azure Cli](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli?view=azure-cli-latest) - faster## Azure Portal
Make sure you are logged in to [Azure Portal](https://portal.azure.com).### 1. Deployment (Portal)
Click magick button (you can open it in new tab):
[![Deploy to Azure](https://aka.ms/deploytoazurebutton)](https://portal.azure.com/#create/Microsoft.Template/uri/https%3A%2F%2Fraw.githubusercontent.com%2FORBA%2Fazure-locust%2Fmaster%2FmainTemplate.json)
Then fill form with given values.
- **Subscription:** choose your subscription
- **Resource Group:** select existing Resource Group or create new one
- **Location:** North Europe (any allowed, but keep in mind its part of Locust DNS address!)
- **Instances (optional):** number of slaves (one slave ~600rps)![Custom Deployment](docs/custom-deployment.png)
Click **Purchase** and wait for deployment ends. Follow notifications on Azure Portal:
![Notification](docs/locust-notification.png)
Click **Go to resource group** to verify your deployment:
![Resource Group](docs/locust-rg.png)
Go to `xxxxxxxxxxxxx-master` and find out Locust FQDN - copy it.
![Locust Master](docs/locust-master.png)
### 2. Go to dashboard (Portal)
When deployment succeeded, your load generator is ready. Go to the above FQDN and port 8089:
`http://xxxxxxxxxxxxx-master.northeurope.azurecontainer.io:8089`
At this point you can start tests.
![Locust Ready](docs/locust-ready.png)
### 3. Updating script (Portal)
Go to your Resource Group and click **Storage Account** named `xxxxxxxxxxxxx`.
![Edit Storage](docs/locust-sa.png)
Click _File shares_ (scroll panel down).
Go to share called `scripts` and edit `locustfile.py` (click `...` and edit).
Edit contents of your new file and click _Save_.![Edit Storage](docs/locust-save.png)
Then restart all containers called like *master* and *slave*.
![Acis](docs/locust-acis.png)
Click on each container to restart it:
![Reset](docs/locust-restart.png)
**Tip:** This step is really faster using Azure CLI.
### 4. Cleanup (Portal)
Go to your Resource Group and remove it (it will destroy all resources inside group).
You will need to type Resource Group name to confirm.![Remove](docs/locust-rm.png)
## Azure CLI
Login and set subscription context
```
az login
az account set --subscription
```### 1. Deployment (CLI)
**Step 1:** Setup your names
```
export RG=
```**Step 2:** Create Resource Group (if not exists)
```
az group create --name ${RG} --location northeurope
```**Step 3:** Deploy ARM template
```
az group deployment create --resource-group ${RG} --query properties.outputs --template-file mainTemplate.json
```
- To change number of instances append `--parameters instances=`**Step 4:** Note values of `prefix` and `url` from console output.
```json
{
"outputs": {
"prefix": {
"type": "String",
"value": "xxxxxxxxxxxxx"
},
"url": {
"type": "String",
"value": "http://xxxxxxxxxxxxx-master.northeurope.azurecontainer.io:8089"
}
}
}
```### 2. Go to dashboard (CLI)
When deployment succeeded, your load generator is ready. Go to above `url` address.
At this point you can start tests.
### 3. Update script (CLI)
Upload your custom script. Replace account name with above `prefix`. You can change `--source` param if you want use different .py file:
```
az storage file upload --account-name -s scripts --source locustfile.py --path locustfile.py
```
Then restart containers:
```
az container list --resource-group ${RG} --query '[].name' -o tsv | xargs -I {} az container restart --no-wait --resource-group ${RG} --name {}
```### 4. Cleanup (CLI)
Remove resources from Azure:
```
az group delete --name ${RG} --yes
```## Disclaimer
* Load test affects target service performance. Never run load tests without service owner permission!
* Some services can block traffic from generator - you should whitelist Azure Region IPs ([Download prefixes](https://www.microsoft.com/download/details.aspx?id=56519)).
* After load tests cleanup Azure resources. You will be billed for running Azure Contianers Instance and Storage Account usage. You can check cost of ACI [here](https://azure.microsoft.com/en-us/pricing/details/container-instances/).