Skip to content

Latest commit

 

History

History
 
 

performance

Performance Tests

Pre-requisites

Install Knative Serving

We install a specific version of Knative - v1.5.0 - as this is a point-in-time guide. While we expect subsequent versions to continue working the same way, in the absence of automated tests that ensure this, we stick to exact versions that we have tested manually.

# Installing Knative Serving ... https://github.com/knative/serving/releases
kubectl apply --filename https://github.com/knative/serving/releases/download/knative-v1.5.0/serving-crds.yaml
kubectl apply --filename https://github.com/knative/serving/releases/download/knative-v1.5.0/serving-core.yaml

# Installing Knative Serving Kourier networking layer ... https://github.com/knative/net-kourier/releases
kubectl apply --filename https://github.com/knative/net-kourier/releases/download/knative-v1.5.0/kourier.yaml

# Patching Knative Serving to use Kourier for the networking layer ...
kubectl patch configmap/config-network \
  --namespace knative-serving \
  --type merge \
  --patch '{"data":{"ingress.class":"kourier.ingress.networking.knative.dev"}}'

Install Eventing RabbitMQ

# Installing Knative Eventing ... https://github.com/knative/eventing/releases
kubectl apply --filename https://github.com/knative/eventing/releases/download/knative-v1.5.0/eventing-crds.yaml
kubectl apply --filename https://github.com/knative/eventing/releases/download/knative-v1.5.0/eventing-core.yaml

# Installing RabbitMQ Operator ... https://github.com/rabbitmq/cluster-operator/releases
kubectl apply --filename https://github.com/rabbitmq/cluster-operator/releases/download/v1.13.0/cluster-operator.yml

# Installing cert-manager 1.5.x ... https://github.com/jetstack/cert-manager/releases
curl -sL https://github.com/jetstack/cert-manager/releases/download/v1.8.0/cert-manager.yaml \
| sed 's/kube-system/cert-manager/' \
| kubectl apply --namespace cert-manager --filename -

# Installing RabbitMQ Messaging Topology Operator with cert-manager integration ... https://github.com/rabbitmq/messaging-topology-operator/releases
kubectl apply --filename https://github.com/rabbitmq/messaging-topology-operator/releases/download/v1.6.0/messaging-topology-operator-with-certmanager.yaml


# Installing Eventing RabbitMQ Broker ... https://github.com/knative-sandbox/eventing-rabbitmq/releases
kubectl apply --filename https://github.com/knative-sandbox/eventing-rabbitmq/releases/download/knative-v1.5.0/rabbitmq-broker.yaml

# Installing Eventing RabbitMQ Source ... https://github.com/knative-sandbox/eventing-rabbitmq/releases
kubectl apply --filename https://github.com/knative-sandbox/eventing-rabbitmq/releases/download/knative-v1.5.0/rabbitmq-source.yaml

Broker Benchmarks

In case you want to test the latest dev version of the eventing-rabbitmq Broker, follow these steps:

git clone https://github.com/knative-sandbox/eventing-rabbitmq $GOPATH/src/knative.dev/eventing-rabbitmq
cd $GOPATH/src/knative-dev/eventing-rabbitmq
ko apply --filename config/broker

Run Eventing RabbitMQ Broker benchmarks

cd $GOPATH/src/knative.dev/eventing-rabbitmq
# If this directory is missing, run:
# git clone https://github.com/knative-sandbox/eventing-rabbitmq $GOPATH/src/knative.dev/eventing-rabbitmq
export PARALLELISM=100
envsubst < test/performance/source-setup/100-broker-perf-setup.yaml | ko apply --filename -
kubectl wait --for=condition=AllReplicasReady=true rmq/rabbitmq-test-cluster --timeout=10m --namespace perf-eventing
kubectl wait --for=condition=IngressReady=true brokers/rabbitmq-test-broker --timeout=10m --namespace perf-eventing
kubectl wait --for=condition=SubscriberResolved=true triggers/rabbitmq-trigger-perf --timeout=10m --namespace perf-eventing

The default setup has a Trigger's Parallelism value of: rabbitmq.eventing.knative.dev/parallelism: "100"

Change this value to try different scenarios better reflecting your application needs

Now run any of the two test types. To run the increasing load test:

ko apply --filename test/performance/broker-setup/200-broker-increasing-load-setup.yaml

To run the constant load test:

ko apply --filename test/performance/broker-setup/300-broker-constant-load-setup.yaml

To run the multi consumer load test:

envsubst < test/performance/broker-setup/400-broker-multi-consumer-setup.yaml | ko apply --filename -

Click here to learn how to visualize the results

Cleanup

To cleanup performance tests resources run:

kubectl delete --filename test/performance/broker-setup/200-broker-increasing-load-setup.yaml

and/or:

kubectl delete --filename test/performance/broker-setup/300-broker-constant-load-setup.yaml
kubectl delete --filename test/performance/broker-setup/400-broker-multi-consumer-setup.yaml

finally:

kubectl delete --filename test/performance/broker-setup/100-broker-perf-setup.yaml

Source Benchmarks

In case you want to test the latest dev version of the eventing-rabbitmq Source, follow these steps:

git clone https://github.com/knative-sandbox/eventing-rabbitmq $GOPATH/src/knative.dev/eventing-rabbitmq
cd $GOPATH/src/knative-dev/eventing-rabbitmq
ko apply --filename config/source

Run Eventing RabbitMQ Source benchmarks

cd $GOPATH/src/knative.dev/eventing-rabbitmq
kubectl apply --filename test/performance/source-setup/100-rabbitmq-setup.yaml
kubectl wait --for=condition=AllReplicasReady=true rmq/rabbitmq-test-cluster --timeout=10m --namespace perf-eventing
kubectl wait --for=condition=IngressReady=true brokers/rabbitmq-test-broker --timeout=10m --namespace perf-eventing
export EXCHANGE_NAME=$(kubectl get exchanges -n perf-eventing -o jsonpath={.items[0].metadata.name})
export PARALLELISM=100
envsubst < test/performance/source-setup/200-source-perf-setup.yaml | kubectl apply --filename -

The default setup has a Source's Parallelism value of: channel.parallelism: 100

Change this value to try different scenarios better reflecting your application needs

Now run any of the two test types. To run the increasing load test:

ko apply --filename test/performance/source-setup/300-source-increasing-load-setup.yaml

To run the constant load test:

ko apply --filename test/performance/source-setup/400-source-constant-load-setup.yaml

Click here to learn how to visualize the results

Cleanup

To cleanup performance tests resources run:

kubectl delete --filename test/performance/source-setup/200-source-increasing-load-setup.yaml

and/or:

kubectl delete --filename test/performance/source-setup/300-broker-constant-load-setup.yaml
kubectl delete --filename test/performance/source-setup/400-broker-multi-consumer-setup.yaml

finally:

kubectl delete --filename test/performance/broker-setup/100-source-perf-setup.yaml

Download & visualize Eventing RabbitMQ benchmark results

Pre-requisite: gnuplot (on macOS it's brew install gnuplot)

cd $GOPATH/src/knative.dev/eventing-rabbitmq
kubectl wait --for=condition=complete job/rabbitmq-broker/source-perf-send-receive --timeout=10m --namespace perf-eventing
kubectl port-forward rabbitmq-broker/source-perf-aggregator 10001:10001 --namespace perf-eventing

# in a new split/tab/window
cd $GOPATH/src/knative.dev/eventing-rabbitmq/test/performance
curl http://localhost:10001/results > eventing-rabbitmq-broker/source-perf-results.csv
gnuplot -c test/performance/latency-throughput.plg eventing-rabbitmq-broker/source-perf-results.csv 0.8 0 1100
# this can take up to 5 minutes to render ¯\_(ツ)_/¯
Try using higher boundaries values for the multi-consumer test setup

What do the 0.8 0 1100 arguments mean?

  • 0.8 is the time in seconds, and it is the max allowed size for the y1 axis
  • 0 and 1100 are the message throughput, and it they represent the min and max boundaries of the y2 axis

latency-throughput

To visualize just the end-to-end event latency, run:

gnuplot -c latency.plg eventing-rabbitmq-broker/source-perf-results.csv 0.8 0 1500

latency

To visualize just the end-to-end event throughput, run:

gnuplot -c throughput.plg eventing-rabbitmq-broker-perf-results.csv 0.8 0 1100
# this can take up to 5 minutes to render ¯\_(ツ)_/¯

throughput

Generate Results for a Release

There is a script for this in the performance tests directory:

cd $GOPATH/src/knative.dev/eventing-rabbitmq/test/performance/
sh ./create-benchmarks.sh -h

And to create the release results:

sh ./create-benchmarks.sh release-vx.y

Verify that everything is working in the results directory

cd $GOPATH/src/knative.dev/eventing-rabbitmq/test/performance/results/release-vx.y

And there you go, your result graphs have been generated!