The workload generators leverage the Locust python framework for generating load against the exposed REST APIs of the sample services.
The workloads can be run via a web interface or the command line.
If using the web interface, you can point your web browser to the exposed port to set the workload's concurrency in terms of "users". Then the load runs until the test is stopped in the browser.
Various charts are provided by the web interface to indicate the performance of the load test.
If you do not want to use the web interface, the command line options specify the user concurrency, as well as a run time. Statistics are printed on the command line for the test.
You can run these workloads either locally or on GKE. Before the workloads can be used, first deploy the backend services according to the README.
Currently, only the web interface is available for workloads running on GKE.
After the workloads are running, then you can use kubectl
or the Cloud Console to get the service IPs for the website.
For example, to get the profile workload, use the following command to get the ETERNAL_IP:
# The external IP is the 4th column of the output
kubectl get services | grep profile-workload
NOTE: If you get an error with kubectl, make sure to authenticate with gcloud according to the instructions in the main README.
When you have that, open a browser to `http://{EXTERNAL_IP}:8089'. This should take you to the Locust Web UI.
Fill in the information for the workload and start the workload.
TIP: You can use the name of the backend-service in the host field, since GKE will use DNS to resolve correctly. For example, use
http://profile
for the profile-workload to connect to the profile backend service.
Do this for each workload.
There are several dependencies required to get the generators to work:
- Python 3.7+
- Locust
Assuming python3.X is installed, install dependencies via pip:
# if pip3 is symlinked to pip
pip install -r requirements.txt
# if pip3 is not symlinked to pip
pip3 install -r requirements.txt
NOTE: To avoid modifying existing pip libraries on your machine, consider a solution like virtualenv.
The provided workload generators do the following:
- authentication_server.py: mimics player signup, player logins, player retrieval by UUID and player logouts
Run on the CLI:
locust -H http://127.0.0.1:8080 -f ./workloads/profile/authentication_server.py --headless -u=2 -r=2 -t=10s
Run webUI on port 8090:
locust --web-port 8090 -f ./workloads/profile/authentication_server.py
# Connect browser to http://localhost:8090
- match_server.py: mimics game servers matching players together, and closing games out.
Run on the CLI:
locust -H http://127.0.0.1:8081 -f ./workloads/matchmaking/match_server.py --headless -u=1 -r=1 -t=10s
Run on port 8091:
locust --web-port 8091 -f ./workloads/matchmaking/match_server.py
# Connect browser to http://localhost:8091
- item_generator.py: generates some random items for our game to use.
Run on the CLI for 1 minute:
locust -H http://127.0.0.1:8082 -f ./workloads/item_generator.py --headless -u=1 -r=1 -t=60s
- game_server.py: mimics adding loot and money to players during the course of a game
Run on the CLI:
locust -H http://127.0.0.1:8082 -f ./workloads/game/game_server.py --headless -u=1 -r=1 -t=10s
Run on port 8092:
locust --web-port 8092 -f ./workloads/game/game_server.py
# Connect browser to http://localhost:8092
- trading_server.py: mimics posting and closing orders on trading post
Run on the CLI:
locust -H http://127.0.0.1:8083 -f ./workloads/tradepost/trading_server.py --headless -u=1 -r=1 -t=10s
Run on port 8093:
locust --web-port 8093 -f ./workloads/tradepost/trading_server.py
# Connect browser to http://localhost:8093