1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-11-29 16:30:56 -05:00
denoland-deno/docs/examples/tcp_echo.md
2021-07-12 19:44:42 +02:00

1.2 KiB

TCP echo server

Concepts

  • Listening for TCP port connections with Deno.listen.
  • Use copy to take inbound data and redirect it to be outbound data.

Example

This is an example of a server which accepts connections on port 8080, and returns to the client anything it sends.

/**
 * echo_server.ts
 */
import { copy } from "https://deno.land/std@$STD_VERSION/io/util.ts";
const listener = Deno.listen({ port: 8080 });
console.log("listening on 0.0.0.0:8080");
for await (const conn of listener) {
  copy(conn, conn).finally(() => conn.close());
}

Run with:

deno run --allow-net echo_server.ts

To test it, try sending data to it with netcat (Linux/MacOS only). Below 'hello world' is sent over the connection, which is then echoed back to the user:

$ nc localhost 8080
hello world
hello world

Like the cat.ts example, the copy() function here also does not make unnecessary memory copies. It receives a packet from the kernel and sends back, without further complexity.