Knative performance tests are tests geared towards producing useful performance metrics of the knative system. As such they can choose to take a closed-box point-of-view of the system and use it just like an end-user might see it. They can also go more open-boxy to narrow down the components under test.
Knative uses vegeta to generate HTTP load. It can be configured to generate load at a predefined rate. Officially it supports constant rate and sine rate, but if you want to generate load at a different rate, you can write your own pacer by implementing Pacer interface. Custom pacer implementations used in Knative tests are under pacers.
The benchmarks were originally built to use mako, but currently running without connecting to the Mako backend, and collecting the data using a Mako sidecar stub.
To run a benchmark once, and use the result from mako-stub
for plotting:
-
Start the benchmarking job:
ko apply -f test/performance/benchmarks/deployment-probe/continuous/benchmark-direct.yaml
-
Wait until all the pods with the selector equal to the job name are completed.
-
Retrieve results from mako-stub using the script in where
pod_name
is the name of the pod from the previous step.
read_results.sh "$pod_name" "$pod_namespace" ${mako_port:-10001} ${timeout:-120} ${retries:-100} ${retries_interval:-10} "$output_file"
This will download a CSV with all raw results. Alternatively you can remove
the port argument -p
in mako-stub
container to dump the output to
container log directly.
Note: Running performance-tests-mako.sh
creates a cluster and runs all the benchmarks in sequence. Results are downloaded in a temp folder
Running performance-tests.sh
runs performance tests using kperf