1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-03 12:58:54 -05:00

benchmarks: fix max_memory and clean up (#2137)

This commit is contained in:
Ryan Dahl 2019-04-17 10:52:36 -04:00 committed by GitHub
parent 8477daa8b9
commit f20b05af24
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 72 additions and 59 deletions

View file

@ -125,13 +125,13 @@ def get_strace_summary(test_args):
return strace_parse(get_strace_summary_text(test_args)) return strace_parse(get_strace_summary_text(test_args))
def run_thread_count_benchmark(deno_path): def run_thread_count_benchmark(deno_exe):
thread_count_map = {} thread_count_map = {}
thread_count_map["set_timeout"] = get_strace_summary([ thread_count_map["set_timeout"] = get_strace_summary([
deno_path, "--reload", "tests/004_set_timeout.ts" deno_exe, "--reload", "tests/004_set_timeout.ts"
])["clone"]["calls"] + 1 ])["clone"]["calls"] + 1
thread_count_map["fetch_deps"] = get_strace_summary([ thread_count_map["fetch_deps"] = get_strace_summary([
deno_path, "--reload", "--allow-net", "tests/fetch_deps.ts" deno_exe, "--reload", "--allow-net", "tests/fetch_deps.ts"
])["clone"]["calls"] + 1 ])["clone"]["calls"] + 1
return thread_count_map return thread_count_map
@ -145,12 +145,12 @@ def run_throughput(deno_exe):
return m return m
def run_syscall_count_benchmark(deno_path): def run_syscall_count_benchmark(deno_exe):
syscall_count_map = {} syscall_count_map = {}
syscall_count_map["hello"] = get_strace_summary( syscall_count_map["hello"] = get_strace_summary(
[deno_path, "--reload", "tests/002_hello.ts"])["total"]["calls"] [deno_exe, "--reload", "tests/002_hello.ts"])["total"]["calls"]
syscall_count_map["fetch_deps"] = get_strace_summary( syscall_count_map["fetch_deps"] = get_strace_summary(
[deno_path, "--reload", "--allow-net", [deno_exe, "--reload", "--allow-net",
"tests/fetch_deps.ts"])["total"]["calls"] "tests/fetch_deps.ts"])["total"]["calls"]
return syscall_count_map return syscall_count_map
@ -164,10 +164,47 @@ def find_max_mem_in_bytes(time_v_output):
return int(value) * 1024 return int(value) * 1024
def run_max_mem_benchmark(deno_path): def run_max_mem_benchmark(deno_exe):
cmd = ["/usr/bin/time", "-v", deno_path, "--reload", "tests/002_hello.ts"] results = {}
for (name, args) in exec_time_benchmarks:
cmd = ["/usr/bin/time", "-v", deno_exe] + args
try:
out = subprocess.check_output(cmd, stderr=subprocess.STDOUT) out = subprocess.check_output(cmd, stderr=subprocess.STDOUT)
return find_max_mem_in_bytes(out) except subprocess.CalledProcessError:
pass
mem = find_max_mem_in_bytes(out)
results[name] = mem
return results
def run_exec_time(deno_exe, build_dir):
benchmark_file = os.path.join(build_dir, "hyperfine_results.json")
hyperfine = prebuilt.load_hyperfine()
run([
hyperfine, "--ignore-failure", "--export-json", benchmark_file,
"--warmup", "3"
] + [
deno_exe + " " + " ".join(args) for [_, args] in exec_time_benchmarks
])
hyperfine_results = read_json(benchmark_file)
results = {}
for [[name, _], data] in zip(exec_time_benchmarks,
hyperfine_results["results"]):
results[name] = {
"mean": data["mean"],
"stddev": data["stddev"],
"user": data["user"],
"system": data["system"],
"min": data["min"],
"max": data["max"]
}
return results
def run_http(build_dir, new_data):
stats = http_benchmark(build_dir)
new_data["req_per_sec"] = {k: v["req_per_sec"] for k, v in stats.items()}
new_data["max_latency"] = {k: v["max_latency"] for k, v in stats.items()}
def main(argv): def main(argv):
@ -179,68 +216,44 @@ def main(argv):
print "Usage: tools/benchmark.py [build_dir]" print "Usage: tools/benchmark.py [build_dir]"
sys.exit(1) sys.exit(1)
sha1 = run_output(["git", "rev-parse", "HEAD"]).strip()
http_server.spawn() http_server.spawn()
deno_path = os.path.join(build_dir, "deno") deno_exe = os.path.join(build_dir, "deno")
benchmark_file = os.path.join(build_dir, "benchmark.json")
os.chdir(root_path) os.chdir(root_path)
import_data_from_gh_pages() import_data_from_gh_pages()
hyperfine = prebuilt.load_hyperfine()
run([
hyperfine, "--ignore-failure", "--export-json", benchmark_file,
"--warmup", "3"
] + [
deno_path + " " + " ".join(args) for [_, args] in exec_time_benchmarks
])
all_data = read_json(all_data_file)
benchmark_data = read_json(benchmark_file)
sha1 = run_output(["git", "rev-parse", "HEAD"]).strip()
new_data = { new_data = {
"created_at": time.strftime("%Y-%m-%dT%H:%M:%SZ"), "created_at": time.strftime("%Y-%m-%dT%H:%M:%SZ"),
"sha1": sha1, "sha1": sha1,
"binary_size": {},
"thread_count": {},
"syscall_count": {},
"benchmark": {}
}
for [[name, _], data] in zip(exec_time_benchmarks,
benchmark_data["results"]):
new_data["benchmark"][name] = {
"mean": data["mean"],
"stddev": data["stddev"],
"user": data["user"],
"system": data["system"],
"min": data["min"],
"max": data["max"]
} }
# TODO(ry) The "benchmark" benchmark should actually be called "exec_time".
# When this is changed, the historical data in gh-pages branch needs to be
# changed too.
new_data["benchmark"] = run_exec_time(deno_exe, build_dir)
new_data["binary_size"] = get_binary_sizes(build_dir) new_data["binary_size"] = get_binary_sizes(build_dir)
# Cannot run throughput benchmark on windows because they don't have nc or # Cannot run throughput benchmark on windows because they don't have nc or
# pipe. # pipe.
if os.name != 'nt': if os.name != 'nt':
hyper_hello_path = os.path.join(build_dir, "hyper_hello") new_data["throughput"] = run_throughput(deno_exe)
core_http_bench_exe = os.path.join(build_dir, "deno_core_http_bench") run_http(build_dir, new_data)
new_data["throughput"] = run_throughput(deno_path)
stats = http_benchmark(deno_path, hyper_hello_path,
core_http_bench_exe)
new_data["req_per_sec"] = {
k: v["req_per_sec"]
for k, v in stats.items()
}
new_data["max_latency"] = {
k: v["max_latency"]
for k, v in stats.items()
}
if "linux" in sys.platform:
# Thread count test, only on linux
new_data["thread_count"] = run_thread_count_benchmark(deno_path)
new_data["syscall_count"] = run_syscall_count_benchmark(deno_path)
new_data["max_memory"] = run_max_mem_benchmark(deno_path)
if "linux" in sys.platform:
new_data["thread_count"] = run_thread_count_benchmark(deno_exe)
new_data["syscall_count"] = run_syscall_count_benchmark(deno_exe)
new_data["max_memory"] = run_max_mem_benchmark(deno_exe)
print "===== <BENCHMARK RESULTS>"
print json.dumps(new_data, indent=2)
print "===== </BENCHMARK RESULTS>"
all_data = read_json(all_data_file)
all_data.append(new_data) all_data.append(new_data)
write_json(all_data_file, all_data) write_json(all_data_file, all_data)
write_json(recent_data_file, all_data[-20:]) write_json(recent_data_file, all_data[-20:])

View file

@ -58,10 +58,10 @@ def hyper_http_benchmark(hyper_hello_exe):
return run(hyper_cmd) return run(hyper_cmd)
def http_benchmark(deno_exe, hyper_hello_exe, core_http_bench_exe): def http_benchmark(build_dir):
hyper_hello_exe = os.path.join(build_dir, "hyper_hello")
# TODO Rename to "deno_tcp" core_http_bench_exe = os.path.join(build_dir, "deno_core_http_bench")
deno_exe = os.path.join(build_dir, "deno")
return { return {
"deno": deno_http_benchmark(deno_exe), "deno": deno_http_benchmark(deno_exe),
"deno_net_http": deno_net_http_benchmark(deno_exe), "deno_net_http": deno_net_http_benchmark(deno_exe),