2015-10-30 20:05:34 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Edit as needed -- note that >1000 per host is likely problematic due to Linux kernel limits
|
2015-11-02 21:17:11 +00:00
|
|
|
NUM_CONTAINERS=100
|
2015-10-30 20:05:34 +00:00
|
|
|
CONTAINER_IMAGE=zerotier/http-test
|
|
|
|
|
|
|
|
#
|
|
|
|
# This script is designed to be run on Docker hosts to run NUM_CONTAINERS
|
|
|
|
#
|
|
|
|
# It can then be run on each Docker host via pssh or similar to run very
|
|
|
|
# large scale tests.
|
|
|
|
#
|
|
|
|
|
|
|
|
export PATH=/bin:/usr/bin:/usr/local/bin:/usr/sbin:/sbin
|
|
|
|
|
|
|
|
# Kill and clean up old test containers if any -- note that this kills all containers on the system!
|
2015-11-02 19:37:32 +00:00
|
|
|
#docker ps -q | xargs -n 1 docker kill
|
|
|
|
#docker ps -aq | xargs -n 1 docker rm
|
2015-10-30 20:05:34 +00:00
|
|
|
|
|
|
|
# Pull latest if needed -- change this to your image name and/or where to pull it from
|
2015-11-02 19:37:32 +00:00
|
|
|
#docker pull $CONTAINER_IMAGE
|
2015-10-30 20:05:34 +00:00
|
|
|
|
|
|
|
# Run NUM_CONTAINERS
|
2015-11-02 19:37:32 +00:00
|
|
|
#for ((n=0;n<$NUM_CONTAINERS;n++)); do
|
|
|
|
# docker run --device=/dev/net/tun --privileged -d $CONTAINER_IMAGE
|
|
|
|
#done
|
|
|
|
|
2015-11-02 21:17:11 +00:00
|
|
|
pssh -h big-test-hosts -i -t 128 -p 256 "for ((n=0;n<$NUM_CONTAINERS;n++)); do docker run --device=/dev/net/tun --privileged -d $CONTAINER_IMAGE; sleep 0.25; done"
|
2015-10-30 20:05:34 +00:00
|
|
|
|
|
|
|
exit 0
|