Skip to main content
Module

std/node/net.ts>createServer

Deno standard library
Go to Latest
The Standard Library has been moved to JSR. See the blog post for details.
function createServer
import { createServer } from "https://deno.land/std@0.145.0/node/net.ts";

Creates a new TCP or IPC server.

Accepts an options object with properties allowHalfOpen (default false) and pauseOnConnect (default false).

If allowHalfOpen is set to false, then the socket will automatically end the writable side when the readable side ends.

If allowHalfOpen is set to true, when the other end of the socket signals the end of transmission, the server will only send back the end of transmission when socket.end() is explicitly called. For example, in the context of TCP, when a FIN packed is received, a FIN packed is sent back only when socket.end() is explicitly called. Until then the connection is half-closed (non-readable but still writable). See "end" event and RFC 1122 (section 4.2.2.13) for more information.

pauseOnConnect indicates whether the socket should be paused on incoming connections.

If pauseOnConnect is set to true, then the socket associated with each incoming connection will be paused, and no data will be read from its handle. This allows connections to be passed between processes without any data being read by the original process. To begin reading data from a paused socket, call socket.resume().

The server can be a TCP server or an IPC server, depending on what it listen() to.

Here is an example of an TCP echo server which listens for connections on port 8124:

import { createRequire } from "https://deno.land/std@0.145.0/node/module.ts";
import { Socket } from "https://deno.land/std@0.145.0/node/net.ts";

const require = createRequire(import.meta.url);
const net = require("net");

const server = net.createServer((c: Socket) => {
  // "connection" listener.
  console.log("client connected");
  c.on("end", () => {
    console.log("client disconnected");
  });
  c.write("hello\r\n");
  c.pipe(c);
});

server.on("error", (err: Error) => {
  throw err;
});

server.listen(8124, () => {
  console.log("server bound");
});

Test this by using telnet:

$ telnet localhost 8124

Parameters

optional
options: ServerOptions

Socket options.

optional
connectionListener: ConnectionListener

Automatically set as a listener for the "connection" event.

Returns

A net.Server.