-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbenchmark_docker.sh
executable file
·119 lines (103 loc) · 3.37 KB
/
benchmark_docker.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#!/bin/sh
usage() { echo "USAGE: sh $0 [OPTIONS]
OPTIONS:
-h display help
-e <dockerimage> execute the given docker image (should be build from ./Dockerfile)
-f <frequency> set the timestep between calls to spawn new containers in seconds -- default 10
-i <path/to/image> original image file path
-o <resultfilename> write timestamp IDs to the given file once docker exits
-p <outputdir> pass '-p outdir' on to start_docker.sh
-t <duration> set the duration of the benchmark in seconds -- default 60
-w <duration> set the duration of the warmup time prior to the benchmark -- default 60
-x <width> width of thumbnail -- defaults to 150
-y <height> height of thumbnail -- defaults to match width
-c crop the image to exactly fill the given thumbnail dimensions
" 1>&2; exit 1; }
DOCKERIMG=
BENCHFILE=
OUTDIR=
FREQUENCY="10"
TESTTIME="60"
WARMTIME="60"
IMAGE=
WIDTH=150
HEIGHT=
CROP=
while getopts ":he:f:i:o:p:t:w:x:y:c" OPT; do
case "$OPT" in
h)
usage
;;
e)
DOCKERIMG="$OPTARG"
;;
f)
FREQUENCY="$OPTARG"
;;
i)
IMAGE="$OPTARG"
;;
o)
BENCHFILE="$OPTARG"
;;
p)
OUTDIR="$OPTARG"
;;
t)
TESTTIME="$OPTARG"
;;
w)
WARMTIME="$OPTARG"
;;
x)
WIDTH="$OPTARG"
;;
y)
HEIGHT="$OPTARG"
;;
c)
CROP="-c"
;;
*)
echo "ERROR: unknown option: $OPT"
usage
;;
esac
done
shift $((OPTIND - 1)) # isolate remaining args (which should be script filenames)
[ -n "$IMAGE" ] || { echo "ERROR: missing required argument: -i <path/to/image>"; usage; }
[ -f "$IMAGE" ] || { echo "ERROR: image file does not exist: $IMAGE"; exit 1; }
[ -n "$HEIGHT" ] || HEIGHT="$WIDTH"
TS="$(date +%s%N)" # get current time in nanoseconds -- good enough for unique timestamp
NAME="benchmark-docker-$TS"
if [ ! -n "$DOCKERIMG" ]; then
DOCKERIMG="$NAME"
sh build_docker.sh "$DOCKERIMG"
fi
[ -n "$BENCHFILE" ] || BENCHFILE="$NAME-results.txt"
[ -n "$OUTDIR" ] || OUTDIR="$NAME-output"
TOTAL=$(python3 -c "print(int(($WARMTIME+$TESTTIME)/$FREQUENCY*1.1))")
echo "Warmup time: $WARMTIME"
echo "Test time: $TESTTIME"
echo "Container spawn interval: $FREQUENCY"
echo "Total containers to create (total necessary * 1.1): $TOTAL"
write_begin_end() {
sleep "$WARMTIME"
echo "BEGIN BENCHMARK: ID $TS at $(date +%s%N)" >> "$BENCHFILE"
sleep "$TESTTIME"
echo "END BENCHMARK: ID $TS at $(date +%s%N)" >> "$BENCHFILE"
}
write_begin_end &
i=1
#for ((i=1;i<=TOTAL;i++)); do
while [ "$i" -le "$TOTAL" ]; do
sh start_docker.sh -b "$BENCHFILE" -e "$DOCKERIMG" -i "$IMAGE" -p "$OUTDIR" -x "$WIDTH" -y "$HEIGHT" $CROP &
printf "\rSpawned container %s" "$i"
sleep "$FREQUENCY"
i=$((i + 1))
done
printf "\n"
# Wait until all containers exit or fail
while [ -n "$(ps -aux | grep -v "grep" | grep -v "benchmark_docker.sh" | grep "$DOCKERIMG")" ]; do sleep 0.1; done
# Remove all docker containers that stopped from this benchmark so that they are cleaned up for future benchmarks
docker system prune -f