File: etcd.sh

package info (click to toggle)
golang-github-rootless-containers-bypass4netns 0.4.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 596 kB
  • sloc: sh: 1,936; python: 542; makefile: 33
file content (150 lines) | stat: -rwxr-xr-x 5,731 bytes parent folder | download | duplicates (2)
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#!/bin/bash
set -eu -o pipefail

cd $(dirname $0)


ETCD_VERSION="v3.3.25"
ETCD_IMAGE="quay.io/coreos/etcd:${ETCD_VERSION}"
BENCH_IMAGE="etcd-bench"

source ~/.profile
. ../param.bash

# sometimes fail to pull images
# this is workaround
# https://github.com/containerd/nerdctl/issues/622
systemctl --user restart containerd
sleep 1
systemctl --user restart buildkit
sleep 3
systemctl --user status --no-pager containerd
systemctl --user status --no-pager buildkit
sudo nerdctl build -f ./Dockerfile -t $BENCH_IMAGE .
nerdctl build -f ./Dockerfile -t $BENCH_IMAGE .

sudo nerdctl pull --quiet $ETCD_IMAGE
nerdctl pull --quiet $ETCD_IMAGE

echo "===== Benchmark: etcd rootful via NetNS ====="
(
  set +e
  sudo nerdctl rm -f etcd-server
  sudo nerdctl rm -f etcd-client
  systemctl --user stop etcd-server
  systemctl --user reset-failed
  set -ex

  sudo nerdctl run -d --name etcd-server $ETCD_IMAGE /bin/sh -c "sleep infinity"
  SERVER_IP=$(sudo nerdctl exec etcd-server hostname -i)
  systemd-run --user --unit etcd-server sudo nerdctl exec etcd-server /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$SERVER_IP:2379
  sleep 5
  LOG_NAME="etcd-rootful-direct.log"
  sudo nerdctl run --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $SERVER_IP:2379 > $LOG_NAME

  sudo nerdctl rm -f etcd-server
  sudo nerdctl rm -f etcd-client
  systemctl --user stop etcd-server
  systemctl --user reset-failed
)

echo "===== Benchmark: etcd rootful via host ====="
(
  set +e
  sudo nerdctl rm -f etcd-server
  sudo nerdctl rm -f etcd-client
  set -ex

  sudo nerdctl run -d --name etcd-server -p 12379:2379 $ETCD_IMAGE /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$HOST_IP:2379
  sleep 5
  LOG_NAME="etcd-rootful-host.log"
  sudo nerdctl run --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $HOST_IP:12379 > $LOG_NAME

  sudo nerdctl rm -f etcd-server
  sudo nerdctl rm -f etcd-client
)

echo "===== Benchmark: etcd client(w/o bypass4netns) server(w/o bypass4netns) via intermediate NetNS ====="
(
  set +e
  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop etcd-server
  systemctl --user reset-failed
  set -ex

  nerdctl run -d --name etcd-server $ETCD_IMAGE /bin/sh -c "sleep infinity"
  SERVER_IP=$(nerdctl exec etcd-server hostname -i)
  systemd-run --user --unit etcd-server nerdctl exec etcd-server /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$SERVER_IP:2379
  sleep 5
  LOG_NAME="etcd-wo-b4ns-direct.log"
  nerdctl run --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $SERVER_IP:2379 > $LOG_NAME

  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop etcd-server
  systemctl --user reset-failed
)

echo "===== Benchmark: etcd client(w/o bypass4netns) server(w/o bypass4netns) via host ====="
(
  set +e
  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  set -ex

  nerdctl run -d --name etcd-server -p 12379:2379 $ETCD_IMAGE /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$HOST_IP:2379
  sleep 5
  LOG_NAME="etcd-wo-b4ns-host.log"
  nerdctl run --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $HOST_IP:12379 > $LOG_NAME

  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
)

echo "===== Benchmark: etcd client(w/ bypass4netns) server(w/ bypass4netns) via host ====="
(
  set +e
  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop run-bypass4netnsd
  systemctl --user reset-failed
  set -ex
  systemd-run --user --unit run-bypass4netnsd bypass4netnsd 

  nerdctl run --annotation nerdctl/bypass4netns=true -d --name etcd-server -p 12379:2379 $ETCD_IMAGE /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$HOST_IP:2379
  sleep 5
  LOG_NAME="etcd-w-b4ns.log"
  nerdctl run --annotation nerdctl/bypass4netns=true --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $HOST_IP:12379 > $LOG_NAME

  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop run-bypass4netnsd
  systemctl --user reset-failed
)

echo "===== Benchmark: etcd client(w/ bypass4netns) server(w/ bypass4netns) with multinode ====="
(
  set +e
  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop run-bypass4netnsd
  systemctl --user stop etcd.service
  systemctl --user reset-failed
  set -ex

  systemd-run --user --unit etcd.service /usr/bin/etcd --listen-client-urls http://$HOST_IP:2379 --advertise-client-urls http://$HOST_IP:2379
  systemd-run --user --unit run-bypass4netnsd bypass4netnsd --multinode=true --multinode-etcd-address=http://$HOST_IP:2379 --multinode-host-address=$HOST_IP

  nerdctl run --annotation nerdctl/bypass4netns=true -d --name etcd-server -p 12379:2379 $ETCD_IMAGE /bin/sh -c "sleep infinity"
  sleep 5
  SERVER_IP=$(nerdctl exec etcd-server hostname -i)
  systemd-run --user --unit etcd-server nerdctl exec etcd-server /usr/local/bin/etcd --listen-client-urls http://0.0.0.0:2379 --advertise-client-urls http://$SERVER_IP:2379
  nerdctl run --annotation nerdctl/bypass4netns=true --rm $BENCH_IMAGE /bench put --key-size=8 --val-size=256 --conns=10 --clients=10 --total=100000 --endpoints $SERVER_IP:2379

  nerdctl rm -f etcd-server
  nerdctl rm -f etcd-client
  systemctl --user stop run-bypass4netnsd
  systemctl --user stop etcd.service
  systemctl --user reset-failed
)