stitcher-benchmark/throughput/request.sh

125 lines
3.1 KiB
Bash
Raw Normal View History

2025-11-17 20:11:26 +07:00
#!/bin/bash
JMX_FILE="./stitcher-benchmark.jmx"
JMETER_CMD="jmeter"
DEFAULT_THREADS=10
DEFAULT_LOOPS=10
2025-11-19 11:33:16 +07:00
SAVE_OUTPUT=""
2025-11-17 20:11:26 +07:00
TARGET_URL=""
2025-11-19 11:33:16 +07:00
TARGET_PORT=5000
2025-11-17 20:11:26 +07:00
THREADS=$DEFAULT_THREADS
LOOPS=$DEFAULT_LOOPS
show_help() {
echo "Usage: $0 -u <AppName> -H <TargetURL> [-t <Threads>] [-l <Loops>]"
echo ""
echo "Runs a JMeter benchmark test with specified parameters."
echo ""
echo "Required Flags:"
2025-11-19 11:33:16 +07:00
echo " -o, --output The output location for the benchmark results."
2025-11-17 20:11:26 +07:00
echo " -H, --host The target URL or IP address for the test (e.g., 10.250.22.29)."
echo ""
echo "Optional Flags:"
2025-11-19 11:33:16 +07:00
echo " -p, --port The target port for the test. Default: 5000."
2025-11-17 20:11:26 +07:00
echo " -t, --threads Number of concurrent threads (users). Default: ${DEFAULT_THREADS}."
echo " -l, --loops Number of loops each thread will execute. Default: ${DEFAULT_LOOPS}."
echo " -h, --help Display this help message and exit."
}
while [[ $# -gt 0 ]]; do
key="$1"
case $key in
-o|--output)
2025-11-19 11:33:16 +07:00
SAVE_OUTPUT="$2"
2025-11-17 20:11:26 +07:00
shift
shift
;;
-H|--host)
TARGET_URL="$2"
shift
shift
;;
2025-11-19 11:33:16 +07:00
-p|--port)
TARGET_PORT="$2"
shift
shift
;;
2025-11-17 20:11:26 +07:00
-t|--threads)
THREADS="$2"
shift
shift
;;
-l|--loops)
LOOPS="$2"
shift
shift
;;
-h|--help)
show_help
exit 0
;;
*)
echo "Unknown option: $1"
show_help
exit 1
;;
esac
done
2025-11-19 11:33:16 +07:00
if [ -z "$SAVE_OUTPUT" ] || [ -z "$TARGET_URL" ]; then
2025-11-17 20:11:26 +07:00
echo "ERROR: Missing required arguments."
echo ""
show_help
exit 1
fi
# --- Define Output Structure ---
2025-11-19 11:33:16 +07:00
MAIN_OUTPUT_DIR="${SAVE_OUTPUT}"
FOLDER_NAME=$(basename "$SAVE_OUTPUT")
RESULT_CSV="${MAIN_OUTPUT_DIR}/${FOLDER_NAME}_benchmark.csv"
RESULT_DASHBOARD="${MAIN_OUTPUT_DIR}/${FOLDER_NAME}_dashboard"
JMETER_LOG_FILE="${MAIN_OUTPUT_DIR}/${FOLDER_NAME}_jmeter.log"
2025-11-17 20:11:26 +07:00
2025-11-19 11:33:16 +07:00
echo "--- Preparing for test run: '$FOLDER_NAME' ---"
2025-11-17 20:11:26 +07:00
mkdir -p "$MAIN_OUTPUT_DIR"
echo "Output will be saved in: $MAIN_OUTPUT_DIR"
echo "Cleaning up previous results..."
rm -f "$RESULT_CSV"
rm -rf "$RESULT_DASHBOARD"
rm -f "$JMETER_LOG_FILE"
echo "Cleanup complete."
echo ""
echo "--- Starting JMeter Benchmark ---"
echo " Target Host: $TARGET_URL"
echo " Concurrency: $THREADS threads"
echo " Iterations: $LOOPS loops per thread"
echo " Total Requests: $((THREADS * LOOPS))"
echo "---------------------------------"
$JMETER_CMD -n \
-t "$JMX_FILE" \
-l "$RESULT_CSV" \
-e -o "$RESULT_DASHBOARD" \
-j "$JMETER_LOG_FILE" \
-Jthreads="$THREADS" \
-Jloops="$LOOPS" \
2025-11-19 11:33:16 +07:00
-Jurl="$TARGET_URL" \
-Jport="$TARGET_PORT"
2025-11-17 20:11:26 +07:00
if [ $? -eq 0 ]; then
echo ""
echo "--- Benchmark Finished Successfully ---"
echo "The HTML report is available here:"
echo "file://$PWD/${RESULT_DASHBOARD}/index.html"
echo "---------------------------------------"
else
echo ""
echo "--- JMeter Finished with an Error ---"
echo "Check the log file for details: ${JMETER_LOG_FILE}"
echo "-------------------------------------"
fi