File: memcached.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 (135 lines) | stat: -rwxr-xr-x 5,129 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
#!/bin/bash
set -eu -o pipefail

cd $(dirname $0)

MEMCACHED_VERSION=1.6.22
MEMCACHED_IMAGE="memcached:${MEMCACHED_VERSION}"

MEMTIRE_VERSION=2.0.0
MEMTIRE_IMAGE="redislabs/memtier_benchmark:${MEMTIRE_VERSION}"

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

sudo nerdctl pull --quiet $MEMCACHED_IMAGE
sudo nerdctl pull --quiet $MEMTIRE_IMAGE
nerdctl pull --quiet $MEMCACHED_IMAGE
nerdctl pull --quiet $MEMTIRE_IMAGE

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

  sudo nerdctl run -d --name memcached-server $MEMCACHED_IMAGE
  SERVER_IP=$(sudo nerdctl exec memcached-server hostname -i)
  LOG_NAME="memcached-rootful-direct.log"
  sudo nerdctl run --name memcached-client $MEMTIRE_IMAGE --host=$SERVER_IP --port=11211 --protocol=memcache_binary --json-out-file=/$LOG_NAME > /dev/null
  sudo nerdctl cp memcached-client:/$LOG_NAME ./$LOG_NAME

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

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

  sudo nerdctl run -d --name memcached-server -p 11212:11211 $MEMCACHED_IMAGE
  LOG_NAME="memcached-rootful-host.log"
  sudo nerdctl run --name memcached-client $MEMTIRE_IMAGE --host=$HOST_IP --port=11212 --protocol=memcache_binary --json-out-file=/$LOG_NAME > /dev/null
  sudo nerdctl cp memcached-client:/$LOG_NAME ./$LOG_NAME

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

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

  nerdctl run -d --name memcached-server $MEMCACHED_IMAGE
  SERVER_IP=$(nerdctl exec memcached-server hostname -i)
  LOG_NAME="memcached-wo-b4ns-direct.log"
  nerdctl run -d --name memcached-client --entrypoint '' $MEMTIRE_IMAGE /bin/sh -c "sleep infinity"
  nerdctl exec memcached-client memtier_benchmark --host=$SERVER_IP --port=11211 --protocol=memcache_binary --json-out-file=/$LOG_NAME > /dev/null
  nerdctl cp memcached-client:/$LOG_NAME ./$LOG_NAME

  nerdctl rm -f memcached-server
  nerdctl rm -f memcached-client
)

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

  nerdctl run -d --name memcached-server -p 11212:11211 $MEMCACHED_IMAGE
  LOG_NAME="memcached-wo-b4ns-host.log"
  nerdctl run -d --name memcached-client --entrypoint '' $MEMTIRE_IMAGE /bin/sh -c "sleep infinity"
  nerdctl exec memcached-client memtier_benchmark --host=$HOST_IP --port=11212 --protocol=memcache_binary --json-out-file=/$LOG_NAME > /dev/null
  nerdctl cp memcached-client:/$LOG_NAME ./$LOG_NAME

  nerdctl rm -f memcached-server
  nerdctl rm -f memcached-client
)

echo "===== Benchmark: memcached client(w/ bypass4netns) server(w/ bypass4netns) via host ====="
(
  set +e
  nerdctl rm -f memcached-server
  nerdctl rm -f memcached-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 memcached-server -p 11212:11211 $MEMCACHED_IMAGE
  LOG_NAME="memcached-w-b4ns.log"
  nerdctl run --annotation nerdctl/bypass4netns=true -d --name memcached-client --entrypoint '' $MEMTIRE_IMAGE /bin/sh -c "sleep infinity"
  nerdctl exec memcached-client memtier_benchmark --host=$HOST_IP --port=11212 --protocol=memcache_binary --json-out-file=/$LOG_NAME > /dev/null
  nerdctl cp memcached-client:/$LOG_NAME ./$LOG_NAME

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


echo "===== Benchmark: memcached client(w/ bypass4netns) server(w/ bypass4netns) with multinode ====="
(
  set +e
  nerdctl rm -f memcached-server
  nerdctl rm -f memcached-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 memcached-server -p 11212:11211 $MEMCACHED_IMAGE
  SERVER_IP=$(nerdctl exec memcached-server hostname -i)
  nerdctl run --annotation nerdctl/bypass4netns=true -d --name memcached-client --entrypoint '' $MEMTIRE_IMAGE /bin/sh -c "sleep infinity"
  nerdctl exec memcached-client memtier_benchmark --host=$SERVER_IP --port=11211 --protocol=memcache_binary

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