-
Notifications
You must be signed in to change notification settings - Fork 1
/
fig_19.py
117 lines (101 loc) · 4.89 KB
/
fig_19.py
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
# MN recovery time -- checkpoint frequency test
# Note: make sure that update duration is 20s
from func_timeout import FunctionTimedOut
from pathlib import Path
import json
import time
from utils.cmd_manager import CMDManager
from utils.log_parser import LogParser
from utils.color_printer import print_GOOD, print_WARNING, print_OK
from utils.func_timer import print_func_time
input_path = './params'
style_path = "./styles"
output_path = './results'
fig_num = '19'
small_fig_num = {'YCSB A': 'a', 'YCSB B': 'b', 'YCSB C': 'c', 'YCSB D': 'd'}
# common params
with (Path(input_path) / f'common.json').open(mode='r') as f:
params = json.load(f)
home_dir = params['home_dir']
ycsb_dir = f'{home_dir}/aceso/ycsb-test'
client_ips = params['client_ips']
master_ip = params['master_ip']
server_ips = params['server_ips']
# fig params
with (Path(input_path) / f'fig_{fig_num}.json').open(mode='r') as f:
fig_params = json.load(f)
methods = fig_params['methods']
MN_num = fig_params['MN_num']
index_sizes = fig_params['index_sizes']
@print_func_time
def main(cmd: CMDManager, tp: LogParser):
plot_data = {
'X_data': index_sizes,
'Y_data': {index_size: {} for index_size in index_sizes},
}
method = 'aceso'
project_dir = f"{home_dir}/{method}"
server_work_dir = f"{project_dir}/build/major-test"
client_work_dir = f"{project_dir}/build/major-test"
server_env_cmd = f"cd {server_work_dir}"
client_env_cmd = f"cd {client_work_dir}"
# only for aceso
memcache_dir = f"{project_dir}/src"
memcache_env_cmd = f"cd {memcache_dir}"
# update and build project
CN_num = len(client_ips)
client_num_per_CN = 8
for index_size in index_sizes:
cmake_option = '-DENABLE_INDEX_SIZE_' + f"{index_size}" + "=on"
SERVER_BUILD_PROJECT = f"cd {project_dir} && mkdir -p build && cd build && rm -f CMakeCache.txt && cmake {cmake_option} .. && make clean && make -j && cd major-test && mkdir -p results"
CLIENT_BUILD_PROJECT = f"cd {project_dir} && mkdir -p build && cd build && rm -f CMakeCache.txt && cmake {cmake_option} .. && make clean && make -j && cd major-test && mkdir -p results"
SET_CN_HUGEPAGE = "echo 4000 | sudo tee /proc/sys/vm/nr_hugepages"
SET_MN_HUGEPAGE = "echo 28000 | sudo tee /proc/sys/vm/nr_hugepages"
UNSET_HUGEPAGE = "echo 0 | sudo tee /proc/sys/vm/nr_hugepages"
KILL_SERVER = f"{server_env_cmd} && killall -9 server"
KILL_SERVER_RECOVER = f"{server_env_cmd} && killall -9 server_recover"
KILL_CLIENT = f"{client_env_cmd} && killall -9 client_perf"
cmd.all_execute(KILL_CLIENT)
cmd.all_execute(UNSET_HUGEPAGE)
cmd.all_execute(CLIENT_BUILD_PROJECT, -1, True)
cmd.server_all_execute(KILL_SERVER)
cmd.server_all_execute(UNSET_HUGEPAGE)
cmd.server_all_execute(SERVER_BUILD_PROJECT, 0, -1, True)
SERVER_START = f"{memcache_env_cmd} && ./run_memcached.sh && {server_env_cmd} && ./server"
MICRO_TEST = f"{client_env_cmd} && ./client_perf update-consume {CN_num} {client_num_per_CN} 8"
while True:
try:
cmd.clear_all_shell()
cmd.server_all_execute(SET_MN_HUGEPAGE, 0, MN_num)
cmd.server_all_long_execute(SERVER_START, 0, MN_num)
cmd.all_execute(SET_CN_HUGEPAGE, CN_num)
cmd.all_long_execute_fig8(MICRO_TEST, CN_num)
time.sleep(10)
cmd.server_all_execute_fast(KILL_SERVER, 1, 2)
cmd.server_all_execute_fast(KILL_SERVER, 1, 2)
cmd.all_execute_fast(KILL_CLIENT, CN_num)
time.sleep(3)
log = cmd.get_server_log()
ckpt_dict = tp.get_ckpt_time(log)
cmd.all_execute(KILL_CLIENT, CN_num)
cmd.all_execute(UNSET_HUGEPAGE, CN_num)
cmd.server_all_execute(KILL_SERVER, 0, MN_num)
cmd.server_all_execute(UNSET_HUGEPAGE, 0, MN_num)
break
except (FunctionTimedOut, Exception) as e:
print_WARNING(f"Error! Retry... {e}")
cmd.all_execute(KILL_CLIENT, CN_num)
cmd.all_execute(UNSET_HUGEPAGE, CN_num)
cmd.server_all_execute(KILL_SERVER, 0, MN_num)
cmd.server_all_execute(UNSET_HUGEPAGE, 0, MN_num)
print_GOOD(f"[FINISHED POINT] method={method} index_size={index_size} ckpt_dict={ckpt_dict}")
plot_data['Y_data'][index_size] = ckpt_dict
# save data
Path(output_path).mkdir(exist_ok=True)
with (Path(output_path) / f'fig_{fig_num}a.json').open(mode='w') as f:
json.dump(plot_data, f, indent=2)
if __name__ == '__main__':
print_WARNING("remember to sudo su && remember first CN's server_id = 0")
cmd = CMDManager(client_ips, master_ip, server_ips)
tp = LogParser()
t = main(cmd, tp)