The loadgen runner automates running any number of load generation cycles on a local or testnet chain, monitoring the local chain node and vats processes. Depending on the use case, it can be ran using a local Agoric SDK repo, or checkout and setup any given revision, with multiple layers of helpers to automate the execution:
loadgen-runner
executable: core tool automating loadgen cycles against an installed agoric SDK (available on PATH)start.sh
script: helper to automate checking out any agoric-sdk revision, compile and install it in a temporary location, and run the load generator with it. Can also be used an existing agoric-sdk repo.- docker image: A Linux Debian environment setup with all dependencies to allow compiling the agoric-sdk. The entrypoint executes the start script, and has mount points for output directory and optionally an SDK repo.
run-daily-perf.sh
script: service entrypoint to continuously execute aloadgen-runner
docker image against the latest revision with the default options.
At the core, the loadgen-runner can be configured to run multiple stages of load generation, either on a local solo chain, or against an existing chain, automatically spawning a ag-solo client and deploying the loadgen tool. It captures the slog file of the local chain node, the state storage of the chain at the end of each stage, and process and disk usage information.
Assuming the agoric-sdk and cosmic-swingset are built and installed, and the agoric cli is available in PATH
.
mkdir -p $HOME/loadgen-output
./runner/bin/loadgen-runner --output-dir=$HOME/loadgen-output
The runner uses yargs-parser
to parse the string command line arguments, and handles dynamically creating a complex argv
object from them. It automatically converts unary arguments into boolean (with support for no-
negation prefix), number conversion, nested objects with dot (.
) notation, and does kebab to camel case conversion.
Currently the following options are available:
--output-dir
: the directory location where to put the results from the loadgen cycles (perf.jsonl
, chain node slogs, chain node storage). Defaults toresults/run-{posixtime}
in the working directory.--profile
: (experimental) the chain target, eitherlocal
(default),testnet
orstage
.--no-monitor
: allows disabling running a chain monitor node (for nonlocal
profiles).--monitor-interval
: a number in minutes for the interval at which to capture process stats for the chain.--no-reset
: a boolean option to control whether the local chain state directory should be checked out clean before starting.--stages
: the total number of stages to run. Default to 6--stage.loadgen.*
: the object to use as default loadgen config for the stages. Created from multiple arguments and passed as-is to the loadgen tool.--stage.duration
: the time in minutes to use as default duration for each loadgen stage (non chain-only, see below). Defaults to 360 minutes (6 hours).--stage.n.*
: Override config for a given stage 0 <= n <--stages
--stage.n.loadgen.*
: the object to use as loadgen config for the given stage. If specified andchain-only
is missing Created from multiple arguments and passed as-is to the loadgen tool.--stage.n.
--stage.n.chain-only
: boolean flag specifying if the stage should only run the chain node and not start a client or loadgen. Defaults totrue
for first and last stage. Defaults tofalse
for other stages, or if--stage.n.loadgen.*
is specified.--stage.n.save-storage
: boolean indicating if the storage of the chain node should be saved at the end of the stage. Defaults totrue
for non stage-only stages (where the loadgen runs), as well as for stage 0 (to capture local bootstrap).--stage.n.duration
: the time in minutes for the stage duration. Defaults to the shared duration above for non chain-only stages, or 0 (immediate stop after start) otherwise. Use a negative value to run until interrupted.
The start script automates checking out and setting up any revision of the Agoric SDK before launching the loadgen-runner. It does so without interfering with an existing sdk installation by default, but can also be pointed to run the setup steps on an existing checked out repository.
All command line arguments are passed through to loadgen-runner
.
OUTPUT_DIR
: directory containing output artifacts. Creates temporary folder derived from revision if not set (/tmp/agoric-sdk-out-{SDK_REVISION}
)SDK_SRC
: directory containingagoric-sdk
repo. Creates temporary folder if not set (/tmp/agoric-sdk-src-{SDK_REVISION}
)SDK_REVISION
: The agoric-sdk git revision to checkout for the test, if no existing repo found. Remote head if not set
SDK_REVISION=fa7ff5e55e OUTPUT_DIR=$HOME/loadgen-output ./start.sh
SDK_SRC=../agoric-sdk ./start.sh --stage.duration=10
The Docker image provides a Linux Debian environment setup with all dependencies to allow compiling the agoric-sdk. The entrypoint executes the start script, and has mount points for output directory and optionally an SDK repo.
/out
: directory containing output artifacts/src
: directory containingagoric-sdk
repo. Automatically checked out if not a git repo (empty)
SDK_REVISION
: The agoric-sdk git revision to checkout for the test
First build the image:
docker build . -t loadgen-runner
To perform a loadgen cycle on a given revision:
OUTPUT_DIR=$HOME/loadgen-output
mkdir -p $OUTPUT_DIR
docker run --rm -v $OUTPUT_DIR:/out -e SDK_REVISION=fa7ff5e55e loadgen-runner --no-reset
To use an existing agoric-sdk copy
OUTPUT_DIR=$HOME/loadgen-output
mkdir -p $OUTPUT_DIR
docker run --rm -v $OUTPUT_DIR:/out -v ../agoric-sdk:/src loadgen-runner --no-reset --stage.duration=10
The script is used as a service entrypoint to continuously execute a loadgen-runner
docker image against the latest SDK revision with the default options. It creates output folders in the current working directory based on the latest revision. The script waits for a new revision to be available if results already exist.
The loadgen is implemented as a dapp deploy script which runs forever, and opens an HTTP server on a local port to receive config updates.
In one terminal:
agoric install
# takes 20s
agoric start local-chain
# wait for "finalizing commit..", takes ~4min
# leave that running
In a second terminal:
agoric start local-solo 8000
# wait for (???), maybe 1min
Then in a third terminal:
yarn loadgen
That will launch several (currently just one) load generation tools. Each
will begin with a setup phase if it has not been run before, using the
ag-solo -side scratch
table to remember the initialized tools.
The load generator listens on localhost port 3352 for generation-rate instructions. The config object maps gnerator name to rate (seconds between cycles). To read the current config:
curl http://127.0.0.1:3352/config
To set the 'faucet' generator to run once per minute:
curl -X PUT --data '{"faucet":{"interval":60}}' http://127.0.0.1:3352/config
To disable all generators:
curl -X PUT --data '{}' http://127.0.0.1:3352/config