const http = require("http");
const server = http.createServer();
server.listen(3000, () => console.log("Server is listening on port 3000. It doesn't do anything, though!"));
This recipe shows you how to create an absolutely minimal server in vanilla Node.
Goals for This Recipe
- Set up the basis for a server in vanilla Node
- Use the http module of Node
To recap: a server is a program that waits for http requests to arrive at a specific port on a computer, and then does something in response. If you're learning Node in the first place, there's a very good chance that creating a server is the main thing you want to do with it. You may want a server to respond to other users trying to connect to your app over the web, or you may want one to handle requests from the visible, frontend part of your app, which needs a server to send it things like images and data. Node has built-in functionality that makes creating a server very easy.
In this recipe you're going to write a bit of code to set up a server and tell it to listen to a port, but that's it--your server is not going to do much other than exist. You'll add code for the server to actually respond to requests in future recipes.
The basic server in this and the next few lessons is written in basic, vanilla Node, without the help of other tools. There's a very popular framework called Express.js which makes creating servers in Node easier, but we'll worry about that later.
Setup
Create a file called server.js
.
To create a server, you're going to be using methods from the Node http
module. This is a core Node module, but not a global one, so you have to import it. Do that at the top of the file with const http = require("http")
.
The http
module contains various methods, properties, and classes for dealing with http requests as both a client and as a server. For now, you need two methods, one to create your server and one to tell it to listen on a port.
Glance over the documentation page for the http module.
The Server interface
One thing that you'll find on the docs page for this module is a section headed "Class: http.Server". This is Server, one of several interfaces that the http module provides. Nested under it are the various methods and properties belonging to the Server interface, and a list of the sort of events it emits. XXXRemember, interfaces are just patterns, which you can use to create objects which have the same methods, properties, etc. as the original.XXX
A Node server is an object. That object is an instance of the Server interface. When you create a server in Node, you're setting up an object which is patterned after Server and has access to all the stuff you see nested under "Class: http.Server" in the docs.
Creating the Server
The first thing you need to do is create a server object. To do that, you need a method from the top level of the http module, http.createServer()
. If you look at the docs and scroll to the bottom of the list of contents, under the documentation for the interfaces, you'll find it down there.
The http.createServer
method is listed as http.createServer([options][, requestListener])
. This shows that it can take two arguments, both of them optional. You're not going to include any arguments in this recipe.
In your server.js
file, under the module import, type const server = http.createServer()
. This creates a server and saves it to the variable server
for later use.
const http = require("http");
const server = http.createServer();
You now have a server, and you can call all the methods/properties of the Server interface on it.
ADD: look at return value of this function in the docs
Setting the Server to Listen
The only server method you need right now is server.listen()
, which tells your server instance to start listening for incoming requests on a port. Add the line server.listen()
to your file. Note that server
here means your specific server instance, the one you created and saved to the server
variable. If you named it something else, like uselessServer
, you would type uselessServer.listen()
.
const http = require("http");
const server = http.createServer();
server.listen();
You now have a server object which will start listening when you run the server.js
file.
Specifying a Port
The http.server.listen()
method accepts arguments. The Node docs do not actually tell you this. Instead, you have to go look at the docs for the net.server.listen()
method, which you'll note is at the bottom of a locked file cabinet in a disused lavatory with a sign on the door reading 'Beware the Leopard' in the docs for an entirely different module. I'm sure this made sense to someone, somewhere, at some point.
You're going to pass your server.listen()
method two arguments. The first is the number of the port you want it to listen on. Modify the last line of your file:
const http = require("http");
const server = http.createServer();
server.listen(3000);
When you run the file, you'll now have a server listening on port 3000.
server.listen()
can also accept a second argument, a callback function which runs when the server starts listening. Usually people use this to console.log a message that the server is running, because it's nice to get some confirmation that it's working. Add a callback like this:
const http = require("http");
const server = http.createServer();
server.listen(3000, () => console.log("Server is listening on port 3000. It doesn't do anything, though!"));
When you run server.js, your code will create a server, set it to listen on port 3000, and output a message telling you it's listening.
To see this, on the command line, navigate to the folder holding your server.js
file and type node server.js
to run it. You should see your confirmation message as output!
To stop your server, press ctrl + C
.
Another Way to Check That Your Server Is Listening
You can get confirmation that your server is working in another way, too. Open a new tab in a web browser and type http://localhost:3000/
in the address bar. Your browser (acting as a client) opens a connection to port 3000 on your machine. The server notices this and sends back a confirmation that it's listening. This has nothing to do with the human-readable confirmation message you've coded it to output when it starts listening; the browser and the server are just waving at each other to confirm they can establish a connection. Only then does your browser send an actual http request. (In this case, it's just asking the server to send it whatever default webpage, etc. the server delivers if you go to that address, just the way your browser expects to be sent the main page of wikipedia if you go to the address https://www.wikipedia.org/.)
Because the browser knows that the server is listening and they have a connection, it will wait for the server to send back a response. However, you haven't given your server any way to respond to the browser yet. You'll see the browser sadly loading and loading and loading before finally timing out. It can see that the lights are on, but no one is coming to the door.
For comparison, go to http://localhost:3001/
, a port you don't have a server listening on. You'll see the browser give up immediately and tell you it can't connect, since there wasn't a server there at all to get its hopes up.
Another Server
Start a new file and create a new server. Give it a different name. Have it listen on a different port and log a different message when it starts listening. For example:
const http = require("http");
const soupServer = http.createServer();
soupServer.listen(3001, () => console.log("Server is listening on port 3000. Wouldn't you love some hot soup?"));
Link to next recipe or section