-
Notifications
You must be signed in to change notification settings - Fork 13
Expand file tree
/
Copy pathjustfile
More file actions
288 lines (220 loc) · 10 KB
/
justfile
File metadata and controls
288 lines (220 loc) · 10 KB
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
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
set positional-arguments
enable_mpk := "0"
enable_pkey_per_func := "0"
enable_file_buffer := "0"
enable_release := "1"
mpk_flag := if enable_mpk == "1" {
if enable_pkey_per_func == "1" {
"pkey_per_func"
} else {
"mpk"
}
} else { "" }
mpk_feature_flag := if mpk_flag == "" { "" } else { "--features " + mpk_flag }
buffer_feature_flag := if enable_file_buffer == "1" { "--features file-based" } else { "" }
release_flag := if enable_release == "1" {
"--release"
} else { "" }
rust_func func_name:
cargo build {{ release_flag }} {{ mpk_feature_flag }} {{ buffer_feature_flag }} \
--manifest-path user/{{ func_name }}/Cargo.toml
libos lib_name:
cargo build {{ release_flag }} {{ if enable_mpk == "1" { "--features mpk" } else { "" } }} \
--manifest-path common_service/{{ lib_name }}/Cargo.toml
pass_args:
just rust_func func_a
just rust_func func_b
map_reduce:
for name in time fdtab fatfs stdio mm; do \
just libos $name; \
done
just rust_func mapper
just rust_func reducer
parallel_sort:
for name in time fdtab fatfs stdio mm; do \
just libos $name; \
done
for func in file_reader sorter splitter merger; do \
just rust_func $func; \
done
long_chain:
for name in time stdio mm; do \
just libos $name; \
done
just rust_func array_sum
simple_file:
just rust_func simple_file
all_libos:
./scripts/build_all_common{{ if enable_mpk == "1" { "_mpk" } else { "" } }}.sh {{ release_flag }}
all_rust:
just all_libos
./scripts/build_user.sh {{ release_flag }} {{ mpk_flag }}
run_rust_test:
just all_libos
just all_rust
./scripts/run_tests.sh {{ mpk_flag }}
cc_flags_p1 := "-Wl,--gc-sections -nostdlib -Wl,--whole-archive"
cc_flags_p2 := "-Wl,--no-whole-archive -shared"
target := "x86_64-unknown-none"
profile := if enable_release == "1" {
"release"
} else {
"debug"
}
symbol_link func_name:
@ln -s $(pwd)/user/{{ func_name }}/target/{{target}}/{{profile}}/lib{{ func_name }}.so target/{{profile}}/
wasm_func func_name:
cd user/{{ func_name }} \
&& cargo build {{ release_flag }} \
--target {{target}} {{mpk_feature_flag}} \
&& cc {{cc_flags_p1}} \
target/{{target}}/{{profile}}/lib{{ func_name }}.a \
{{cc_flags_p2}} \
-o target/{{target}}/{{profile}}/lib{{ func_name }}.so
@-rm target/{{profile}}/lib{{ func_name }}.so
just symbol_link {{ func_name }}
c_wordcount:
just wasm_func wasmtime_mapper
just wasm_func wasmtime_reducer
c_parallel_sort:
just wasm_func wasmtime_sorter
just wasm_func wasmtime_spliter
just wasm_func wasmtime_merger
just wasm_func wasmtime_checker
c_long_chain:
just wasm_func wasmtime_longchain
all_c_wasm: c_wordcount c_parallel_sort c_long_chain
python_wordcount:
just wasm_func wasmtime_cpython_wordcount
python_parallel_sort:
just wasm_func wasmtime_cpython_parallel_sort
python_long_chain:
just wasm_func wasmtime_cpython_func
all_py_wasm: python_wordcount python_parallel_sort python_long_chain
all_wasm: all_c_wasm all_py_wasm
measure_avg isol_file:
#!/bin/bash
for (( i=1; i<=10; i++ )); do \
output=$(cargo run {{ release_flag }} {{mpk_feature_flag}} -- --files {{ isol_file }} --metrics total-dur 2>&1); \
total_dur=$(echo "$output" | grep -o '"total_dur(ms)": [0-9.]*' | awk -F': ' '{print $2}'); \
total_dur_rounded=$(printf "%.3f\n" "$total_dur") ;\
echo "$total_dur_rounded ," ;\
done ;
gen_data:
sudo -E ./scripts/gen_data.py
init:
rustup override set 'nightly-2023-12-01'
rustup target add x86_64-unknown-linux-musl
[ -f fs_images/fatfs.img ] || unzip fs_images/fatfs.zip -d fs_images
[ -d image_content ] || mkdir image_content
asvisor:
cargo build {{ release_flag }}
cold_start_latency: asvisor all_libos
#!/bin/bash
if [ -z "$SUDO_PASSWD" ]; then
echo "Error: SUDO_PASSWD environment variable is not set"
echo "Please set it with: export SUDO_PASSWD=<your_password>" && exit 1
fi
just rust_func hello_world
just rust_func load_all
@-./scripts/del_tap.sh 2>/dev/null
@echo '\ncold start with on-demand loading'
target/{{profile}}/asvisor --files isol_config/base_config.json --metrics total-dur 2>&1 | grep 'ms'
@echo '\ncold start without on-demand loading'
target/{{profile}}/asvisor --files isol_config/load_all.json --metrics total-dur 2>&1 | grep 'ms'
data_transfer_latency: asvisor all_libos
for data_size in '4*1024' '64*1024' '1024*1024' '16*1024*1024' '256*1024*1024'; do \
echo $data_size > user/data_size.config; \
just pass_args 1>/dev/null 2>/dev/null; \
target/{{profile}}/asvisor --files isol_config/pass_complex_args.json 2>&1 | grep 'bytes'; \
echo ''; \
done
end_to_end_latency: asvisor all_libos map_reduce parallel_sort long_chain
-sudo mount fs_images/fatfs.img image_content 2>/dev/null
sudo -E ./scripts/gen_data.py 3 '100 * 1024 * 1024' 3 '25 * 1024 * 1024'
@echo 'word count cost: '
target/{{profile}}/asvisor --files isol_config/map_reduce_large_c3.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'parallel sorting cost: '
target/{{profile}}/asvisor --files isol_config/parallel_sort_c3.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'function chain cost: '
target/{{profile}}/asvisor --files isol_config/long_chain_n15.json --metrics total-dur 2>&1 | grep 'total_dur'
just c_end_to_end_latency
just py_end_to_end_latency
c_end_to_end_latency: asvisor all_libos all_c_wasm
# C applications.
@echo 'C word count cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_wordcount_c3.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'C parallel sorting cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_parallel_sort_c3.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'C function chain cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_longchain.json --metrics total-dur 2>&1 | grep 'total_dur'
py_end_to_end_latency: asvisor all_libos all_py_wasm
# Python applications.
-sudo mount fs_images/fatfs.img image_content 2>/dev/null
sudo -E ./scripts/gen_data.py 1 '1 * 1024 * 1024' 1 '1 * 1024 * 1024'
sleep 5
@echo 'Python word count cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_cpython_wordcount_c1.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'Python parallel sorting cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_cpython_parallel_sort_c1.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo 'Python long chain cost: '
target/{{profile}}/asvisor --files isol_config/wasmtime_cpython_functionchain_n5.json --metrics total-dur 2>&1 | grep 'total_dur'
breakdown: asvisor all_libos
-sudo mount fs_images/fatfs.img image_content 2>/dev/null
-sudo ./scripts/del_tap.sh
sudo -E ./scripts/gen_data.py 5 '10 * 1024 * 1024' 5 '1 * 1024 * 1024'
@echo '1 * 1024 * 1024' > user/function_chain_data_size.config
@echo 'base (-on-demand-loding, -reference-passing)'
for func_name in 'mapper' 'reducer' 'file_reader' 'sorter' 'splitter' 'merger' 'array_sum'; do \
cargo build {{ release_flag }} {{ mpk_feature_flag }} --features file-based --manifest-path user/${func_name}/Cargo.toml; \
done ;
target/{{profile}}/asvisor --files isol_config/map_reduce_load_all.json --metrics total-dur 2>&1 | grep 'total_dur'
sudo rm -f ./image_content/*.imd
target/{{profile}}/asvisor --files isol_config/parallel_sort_load_all.json --metrics total-dur 2>&1 | grep 'total_dur'
sudo rm -f ./image_content/*.imd
target/{{profile}}/asvisor --files isol_config/long_chain_load_all.json --metrics total-dur 2>&1 | grep 'total_dur'
sudo rm -f ./image_content/*.imd
@echo '\n+on-demand-loding (-reference-passing)'
target/{{profile}}/asvisor --files isol_config/map_reduce_large_c5.json --metrics total-dur 2>&1 | grep 'total_dur'
sudo rm -f ./image_content/*.imd
target/{{profile}}/asvisor --files isol_config/parallel_sort_c5.json --metrics total-dur 2>&1 | grep 'total_dur'
sudo rm -f ./image_content/*.imd
target/{{profile}}/asvisor --files isol_config/long_chain_n15.json --metrics total-dur 2>&1 | grep 'total_dur'
@echo '\n+both'
for func_name in 'mapper' 'reducer' 'file_reader' 'sorter' 'splitter' 'merger' 'array_sum'; do \
cargo build {{ release_flag }} {{ mpk_feature_flag }} --manifest-path user/${func_name}/Cargo.toml; \
done ;
target/{{profile}}/asvisor --files isol_config/map_reduce_large_c5.json --metrics total-dur 2>&1 | grep 'total_dur'
target/{{profile}}/asvisor --files isol_config/parallel_sort_c5.json --metrics total-dur 2>&1 | grep 'total_dur'
target/{{profile}}/asvisor --files isol_config/long_chain_n15.json --metrics total-dur 2>&1 | grep 'total_dur'
p99: asvisor all_libos parallel_sort
-sudo mount fs_images/fatfs.img image_content 2>/dev/null
sudo -E ./scripts/gen_data.py 0 0 3 '25 * 1024 * 1024'
@echo 'p99 10'
./p99tester 10 | grep 'p99'
@echo 'p99 20'
./p99tester 20 | grep 'p99'
@echo 'p99 40'
./p99tester 40 | grep 'p99'
@echo 'p99 80'
./p99tester 80 | grep 'p99'
resource_consume: asvisor all_libos parallel_sort
-sudo mount fs_images/fatfs.img image_content 2>/dev/null
sudo -E ./scripts/gen_data.py 0 0 5 '25 * 1024 * 1024'
@sleep 3
@echo 'resource instances 20'
./resourcetester 20 | grep 'total consume mem:'
mv monitor.log as_parallel_sort_resouce_c5_25_20.txt
@sleep 3
@echo 'resource instances 40'
./resourcetester 40 | grep 'total consume mem:'
mv monitor.log as_parallel_sort_resouce_c5_25_40.txt
@sleep 3
@echo 'resource instances 60'
./resourcetester 60 | grep 'total consume mem:'
mv monitor.log as_parallel_sort_resouce_c5_25_60.txt
@sleep 3
@echo 'resource instances 80'
./resourcetester 80 | grep 'total consume mem:'
mv monitor.log as_parallel_sort_resouce_c5_25_80.txt
./scripts/comp_resource.py