#!/bin/sh # # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. # # Benchmark script for comparing cluster performance. # Default options MESSAGES="-m 10000" REPEAT="--repeat 10" QUEUES="-q 6" SENDERS="-s 3" RECEIVERS="-r 3" BROKERS= # Local broker CLIENT_HOSTS= # No ssh, all clients are local # Connection options TCP_NODELAY=false RECONNECT=true HEARTBEAT=1 while getopts "m:f:n:b:q:s:r:c:h:i:txyv-" opt; do case $opt in b) BROKERS="-b $OPTARG";; c) CLIENT_HOSTS="-c $OPTARG";; h) HEARTBEAT=$OPTARG;; i) RECONNECT=$OPTARG;; m) MESSAGES="-m $OPTARG";; n) REPEAT="--repeat $OPTARG";; q) QUEUES="-q $OPTARG";; r) RECEIVERS="-r $OPTARG";; s) SENDERS="-s $OPTARG";; t) TCP_NODELAY=true;; v) OPTS="--verbose";; x) SAVE_RECEIVED="--save-received";; y) NO_DELETE="--no-delete";; -) break ;; *) echo "Unknown option"; exit 1;; esac done shift $(($OPTIND-1)) CONNECTION_OPTIONS="--connection-options {tcp-nodelay:$TCP_NODELAY,reconnect:$RECONNECT,heartbeat:$HEARTBEAT}" BROKER=$(echo $BROKERS | sed s/,.*//) run_test() { echo $*; shift; "$@"; echo; echo; echo; } OPTS="$OPTS $REPEAT $BROKERS --summarize $QUEUES $SENDERS $RECEIVERS $MESSAGES $CLIENT_HOSTS $SAVE_RECEIVED $CONNECTION_OPTIONS $NO_DELETE" run_test "Benchmark:" qpid-cpp-benchmark $OPTS "$@"