mirror of
https://github.com/denoland/deno.git
synced 2024-12-27 17:49:08 -05:00
1ab3691b09
This commit adds a new op_write_all to core that allows writing an entire chunk in a single async op call. Internally this calls `Resource::write_all`. The `writableStreamForRid` has been moved to `06_streams.js` now, and uses this new op. Various other code paths now also use this new op. Closes #16227
49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
|
// This is not a real HTTP server. We read blindly one time into 'requestBuf',
|
|
// then write this fixed 'responseBuf'. The point of this benchmark is to
|
|
// exercise the event loop in a simple yet semi-realistic way.
|
|
const requestBuf = new Uint8Array(64 * 1024);
|
|
const responseBuf = new Uint8Array(
|
|
"HTTP/1.1 200 OK\r\nContent-Length: 12\r\n\r\nHello World\n"
|
|
.split("")
|
|
.map((c) => c.charCodeAt(0)),
|
|
);
|
|
|
|
/** Listens on 0.0.0.0:4500, returns rid. */
|
|
function listen() {
|
|
return Deno.core.ops.op_listen();
|
|
}
|
|
|
|
/** Accepts a connection, returns rid. */
|
|
function accept(serverRid) {
|
|
return Deno.core.opAsync("op_accept", serverRid);
|
|
}
|
|
|
|
async function serve(rid) {
|
|
try {
|
|
while (true) {
|
|
await Deno.core.read(rid, requestBuf);
|
|
await Deno.core.writeAll(rid, responseBuf);
|
|
}
|
|
} catch (e) {
|
|
if (
|
|
!e.message.includes("Broken pipe") &&
|
|
!e.message.includes("Connection reset by peer")
|
|
) {
|
|
throw e;
|
|
}
|
|
}
|
|
Deno.core.close(rid);
|
|
}
|
|
|
|
async function main() {
|
|
const listenerRid = listen();
|
|
Deno.core.print(`http_bench_ops listening on http://127.0.0.1:4544/\n`);
|
|
|
|
while (true) {
|
|
const rid = await accept(listenerRid);
|
|
serve(rid);
|
|
}
|
|
}
|
|
|
|
main();
|