Skip to content

Instantly share code, notes, and snippets.

@jddonovan
Forked from cirocosta/stress-test.sh
Last active September 27, 2022 01:05
Show Gist options
  • Star 2 You must be signed in to star a gist
  • Fork 5 You must be signed in to fork a gist
  • Save jddonovan/c423c7e5bc008df3c4b8e1424fefd504 to your computer and use it in GitHub Desktop.
Save jddonovan/c423c7e5bc008df3c4b8e1424fefd504 to your computer and use it in GitHub Desktop.
naive http server stress tester using cURL
#!/bin/bash
#### Default Configuration
CONCURRENCY=4
REQUESTS=100
ADDRESS="http://localhost:8080/"
show_help() {
cat << EOF
Naive Stress Test with cURL.
Usage: ./stress-test.sh [-a ADDRESS] [-c CONCURRENCY] [-r REQUESTS]
Params:
-a address to be tested.
Defaults to localhost:8080
-c conccurency: how many process to spawn
Defaults to 4
-r number of requests per process
Defaults to 100
-h show this help text
Example:
$ ./stress-test.sh -c 4 -p 100 (400 requests to localhost:8080)
EOF
}
#### CLI
while getopts ":a:c:r:h" opt; do
case $opt in
a)
ADDRESS=$OPTARG
;;
c)
CONCURRENCY=$OPTARG
;;
r)
REQUESTS=$OPTARG
;;
h)
show_help
exit 0
;;
\?)
show_help >&2
echo "Invalid argument: $OPTARG" &2
exit 1
;;
esac
done
shift $((OPTIND-1))
#### Main
for i in `seq 1 $CONCURRENCY`; do
curl --silent --output /dev/null -s "$ADDRESS?[1-$REQUESTS]" & pidlist="$pidlist $!"
done
# Execute and wait
FAIL=0
for job in $pidlist; do
echo $job
wait $job || let "FAIL += 1"
done
# Verify if any failed
if [ "$FAIL" -eq 0 ]; then
echo "SUCCESS!"
else
echo "Failed Requests: ($FAIL)"
fi
@jddonovan
Copy link
Author

Updated for better performance.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment