mirror of
https://github.com/denoland/deno.git
synced 2024-11-25 15:29:32 -05:00
http benchmarks with unique ports (#2471)
This commit is contained in:
parent
9a6cfd653d
commit
4ea2df6759
3 changed files with 62 additions and 33 deletions
|
@ -9,7 +9,7 @@ const originAddr = Deno.args[2] || "127.0.0.1:4501";
|
||||||
const server = serve(addr);
|
const server = serve(addr);
|
||||||
|
|
||||||
async function main(): Promise<void> {
|
async function main(): Promise<void> {
|
||||||
console.log(`http://${addr}/`);
|
console.log(`Proxy listening on http://${addr}/`);
|
||||||
for await (const req of server) {
|
for await (const req of server) {
|
||||||
proxyRequest(req);
|
proxyRequest(req);
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ async function handle(conn: Deno.Conn): Promise<void> {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function main(): Promise<void> {
|
async function main(): Promise<void> {
|
||||||
console.log("Listening on", addr);
|
console.log(`Proxy listening on http://${addr}/`);
|
||||||
while (true) {
|
while (true) {
|
||||||
const conn = await listener.accept();
|
const conn = await listener.accept();
|
||||||
handle(conn);
|
handle(conn);
|
||||||
|
|
|
@ -12,25 +12,36 @@ import subprocess
|
||||||
# "deno_tcp" was once called "deno"
|
# "deno_tcp" was once called "deno"
|
||||||
# "deno_http" was once called "deno_net_http"
|
# "deno_http" was once called "deno_net_http"
|
||||||
|
|
||||||
ADDR = "127.0.0.1:4544"
|
|
||||||
ORIGIN_ADDR = "127.0.0.1:4545"
|
|
||||||
DURATION = "10s"
|
DURATION = "10s"
|
||||||
|
|
||||||
|
LAST_PORT = 4544
|
||||||
|
|
||||||
|
|
||||||
|
def get_addr(port=None):
|
||||||
|
global LAST_PORT
|
||||||
|
if port is None:
|
||||||
|
port = LAST_PORT
|
||||||
|
LAST_PORT = LAST_PORT + 1
|
||||||
|
return ("127.0.0.1:%d" % (port))
|
||||||
|
|
||||||
|
|
||||||
def deno_tcp(deno_exe):
|
def deno_tcp(deno_exe):
|
||||||
deno_cmd = [deno_exe, "run", "--allow-net", "tools/deno_tcp.ts", ADDR]
|
addr = get_addr()
|
||||||
|
deno_cmd = [deno_exe, "run", "--allow-net", "tools/deno_tcp.ts", addr]
|
||||||
print "http_benchmark testing DENO."
|
print "http_benchmark testing DENO."
|
||||||
return run(deno_cmd)
|
return run(deno_cmd, addr)
|
||||||
|
|
||||||
|
|
||||||
def deno_http(deno_exe):
|
def deno_http(deno_exe):
|
||||||
|
addr = get_addr()
|
||||||
deno_cmd = [
|
deno_cmd = [
|
||||||
deno_exe, "run", "--allow-net",
|
deno_exe, "run", "--allow-net",
|
||||||
"js/deps/https/deno.land/std/http/http_bench.ts", ADDR
|
"js/deps/https/deno.land/std/http/http_bench.ts", addr
|
||||||
]
|
]
|
||||||
print "http_benchmark testing DENO using net/http."
|
print "http_benchmark testing DENO using net/http."
|
||||||
return run(
|
return run(
|
||||||
deno_cmd,
|
deno_cmd,
|
||||||
|
addr,
|
||||||
merge_env={
|
merge_env={
|
||||||
# Load from //js/deps/https/deno.land/net/ submodule.
|
# Load from //js/deps/https/deno.land/net/ submodule.
|
||||||
"DENO_DIR": os.path.join(util.root_path, "js")
|
"DENO_DIR": os.path.join(util.root_path, "js")
|
||||||
|
@ -38,75 +49,94 @@ def deno_http(deno_exe):
|
||||||
|
|
||||||
|
|
||||||
def deno_tcp_proxy(deno_exe, hyper_hello_exe):
|
def deno_tcp_proxy(deno_exe, hyper_hello_exe):
|
||||||
|
addr = get_addr()
|
||||||
|
origin_addr = get_addr()
|
||||||
deno_cmd = [
|
deno_cmd = [
|
||||||
deno_exe, "run", "--allow-net", "tools/deno_tcp_proxy.ts", ADDR,
|
deno_exe, "run", "--allow-net", "tools/deno_tcp_proxy.ts", addr,
|
||||||
ORIGIN_ADDR
|
origin_addr
|
||||||
]
|
]
|
||||||
print "http_proxy_benchmark testing DENO using net/tcp."
|
print "http_proxy_benchmark testing DENO using net/tcp."
|
||||||
return run(
|
return run(
|
||||||
deno_cmd,
|
deno_cmd,
|
||||||
|
addr,
|
||||||
merge_env={"DENO_DIR": os.path.join(util.root_path, "js")},
|
merge_env={"DENO_DIR": os.path.join(util.root_path, "js")},
|
||||||
origin_cmd=http_proxy_origin(hyper_hello_exe))
|
origin_cmd=http_proxy_origin(hyper_hello_exe, origin_addr))
|
||||||
|
|
||||||
|
|
||||||
def deno_http_proxy(deno_exe, hyper_hello_exe):
|
def deno_http_proxy(deno_exe, hyper_hello_exe):
|
||||||
|
addr = get_addr()
|
||||||
|
origin_addr = get_addr()
|
||||||
deno_cmd = [
|
deno_cmd = [
|
||||||
deno_exe, "run", "--allow-net", "tools/deno_http_proxy.ts", ADDR,
|
deno_exe, "run", "--allow-net", "tools/deno_http_proxy.ts", addr,
|
||||||
ORIGIN_ADDR
|
origin_addr
|
||||||
]
|
]
|
||||||
print "http_proxy_benchmark testing DENO using net/http."
|
print "http_proxy_benchmark testing DENO using net/http."
|
||||||
return run(
|
return run(
|
||||||
deno_cmd,
|
deno_cmd,
|
||||||
|
addr,
|
||||||
merge_env={"DENO_DIR": os.path.join(util.root_path, "js")},
|
merge_env={"DENO_DIR": os.path.join(util.root_path, "js")},
|
||||||
origin_cmd=http_proxy_origin(hyper_hello_exe))
|
origin_cmd=http_proxy_origin(hyper_hello_exe, origin_addr))
|
||||||
|
|
||||||
|
|
||||||
def deno_core_single(exe):
|
def deno_core_single(exe):
|
||||||
print "http_benchmark testing deno_core_single"
|
print "http_benchmark testing deno_core_single"
|
||||||
return run([exe, "--single-thread"])
|
return run([exe, "--single-thread"], "127.0.0.1:4544")
|
||||||
|
|
||||||
|
|
||||||
def deno_core_multi(exe):
|
def deno_core_multi(exe):
|
||||||
print "http_benchmark testing deno_core_multi"
|
print "http_benchmark testing deno_core_multi"
|
||||||
return run([exe, "--multi-thread"])
|
return run([exe, "--multi-thread"], "127.0.0.1:4544")
|
||||||
|
|
||||||
|
|
||||||
def node_http():
|
def node_http():
|
||||||
node_cmd = ["node", "tools/node_http.js", ADDR.split(":")[1]]
|
addr = get_addr()
|
||||||
|
node_cmd = ["node", "tools/node_http.js", addr.split(":")[1]]
|
||||||
print "http_benchmark testing NODE."
|
print "http_benchmark testing NODE."
|
||||||
return run(node_cmd)
|
return run(node_cmd, addr)
|
||||||
|
|
||||||
|
|
||||||
def node_http_proxy(hyper_hello_exe):
|
def node_http_proxy(hyper_hello_exe):
|
||||||
node_cmd = ["node", "tools/node_http_proxy.js", ADDR.split(":")[1]]
|
addr = get_addr()
|
||||||
|
origin_addr = get_addr()
|
||||||
|
node_cmd = [
|
||||||
|
"node", "tools/node_http_proxy.js",
|
||||||
|
addr.split(":")[1],
|
||||||
|
origin_addr.split(":")[1]
|
||||||
|
]
|
||||||
print "http_proxy_benchmark testing NODE."
|
print "http_proxy_benchmark testing NODE."
|
||||||
return run(node_cmd, None, http_proxy_origin(hyper_hello_exe))
|
return run(node_cmd, addr, None,
|
||||||
|
http_proxy_origin(hyper_hello_exe, origin_addr))
|
||||||
|
|
||||||
|
|
||||||
def node_tcp_proxy(hyper_hello_exe):
|
def node_tcp_proxy(hyper_hello_exe):
|
||||||
|
addr = get_addr()
|
||||||
|
origin_addr = get_addr()
|
||||||
node_cmd = [
|
node_cmd = [
|
||||||
"node", "tools/node_tcp_proxy.js",
|
"node", "tools/node_tcp_proxy.js",
|
||||||
ADDR.split(":")[1],
|
addr.split(":")[1],
|
||||||
ORIGIN_ADDR.split(":")[1]
|
origin_addr.split(":")[1]
|
||||||
]
|
]
|
||||||
print "http_proxy_benchmark testing NODE tcp."
|
print "http_proxy_benchmark testing NODE tcp."
|
||||||
return run(node_cmd, None, http_proxy_origin(hyper_hello_exe))
|
return run(node_cmd, addr, None,
|
||||||
|
http_proxy_origin(hyper_hello_exe, origin_addr))
|
||||||
|
|
||||||
|
|
||||||
def node_tcp():
|
def node_tcp():
|
||||||
node_cmd = ["node", "tools/node_tcp.js", ADDR.split(":")[1]]
|
addr = get_addr()
|
||||||
|
node_cmd = ["node", "tools/node_tcp.js", addr.split(":")[1]]
|
||||||
print "http_benchmark testing node_tcp.js"
|
print "http_benchmark testing node_tcp.js"
|
||||||
return run(node_cmd)
|
return run(node_cmd, addr)
|
||||||
|
|
||||||
|
|
||||||
def http_proxy_origin(hyper_hello_exe):
|
def http_proxy_origin(hyper_hello_exe, addr):
|
||||||
return [hyper_hello_exe, ORIGIN_ADDR.split(":")[1]]
|
return [hyper_hello_exe, addr.split(":")[1]]
|
||||||
|
|
||||||
|
|
||||||
def hyper_http(hyper_hello_exe):
|
def hyper_http(hyper_hello_exe):
|
||||||
hyper_cmd = [hyper_hello_exe, ADDR.split(":")[1]]
|
addr = get_addr()
|
||||||
|
hyper_cmd = [hyper_hello_exe, addr.split(":")[1]]
|
||||||
print "http_benchmark testing RUST hyper."
|
print "http_benchmark testing RUST hyper."
|
||||||
return run(hyper_cmd)
|
return run(hyper_cmd, addr)
|
||||||
|
|
||||||
|
|
||||||
def http_benchmark(build_dir):
|
def http_benchmark(build_dir):
|
||||||
|
@ -131,7 +161,8 @@ def http_benchmark(build_dir):
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def run(server_cmd, merge_env=None, origin_cmd=None):
|
def run(server_cmd, addr, merge_env=None, origin_cmd=None):
|
||||||
|
|
||||||
# Run deno echo server in the background.
|
# Run deno echo server in the background.
|
||||||
if merge_env is None:
|
if merge_env is None:
|
||||||
env = None
|
env = None
|
||||||
|
@ -146,16 +177,15 @@ def run(server_cmd, merge_env=None, origin_cmd=None):
|
||||||
|
|
||||||
origin = None
|
origin = None
|
||||||
if origin_cmd is not None:
|
if origin_cmd is not None:
|
||||||
print "Starting origin server"
|
|
||||||
origin = subprocess.Popen(origin_cmd, env=env)
|
origin = subprocess.Popen(origin_cmd, env=env)
|
||||||
|
|
||||||
server = subprocess.Popen(server_cmd, env=env)
|
server = subprocess.Popen(server_cmd, env=env)
|
||||||
|
|
||||||
time.sleep(15) # wait for server to wake up. TODO racy.
|
time.sleep(10) # wait for server to wake up. TODO racy.
|
||||||
|
|
||||||
try:
|
try:
|
||||||
cmd = "third_party/wrk/%s/wrk -d %s http://%s/" % (util.platform(),
|
cmd = "third_party/wrk/%s/wrk -d %s http://%s/" % (util.platform(),
|
||||||
DURATION, ADDR)
|
DURATION, addr)
|
||||||
print cmd
|
print cmd
|
||||||
output = subprocess.check_output(cmd, shell=True)
|
output = subprocess.check_output(cmd, shell=True)
|
||||||
stats = util.parse_wrk_output(output)
|
stats = util.parse_wrk_output(output)
|
||||||
|
@ -164,7 +194,6 @@ def run(server_cmd, merge_env=None, origin_cmd=None):
|
||||||
finally:
|
finally:
|
||||||
server.kill()
|
server.kill()
|
||||||
if origin is not None:
|
if origin is not None:
|
||||||
print "Stopping origin server"
|
|
||||||
origin.kill()
|
origin.kill()
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue