- GKE 1.21 with autoscaling
- kubectl 1.21
- ko v0.11.2 +
KO_DOCKER_REPO
- A git clone of knative-sandbox/eventing-rabbitmq
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"}}'
# 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
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
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
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
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
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
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
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 axis0
and1100
are the message throughput, and it they represent the min and max boundaries of the y2 axis
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
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 ¯\_(ツ)_/¯
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!