Overview
The http
module provides basic http protocol support and includes the following features:
- Basic http server
- Basic http client
This document focuses on the use of HttpServer. HttpServer supports http and https. http protocol versions are HTTP/1.1. A single server can be created, and a server group (mult-task mode) is also allowed.
User can use the following code to import the http
module and access HttpServer
.
var http = require('http');
Support
The following shows http
module APIs available for each permissions.
User Mode | Privilege Mode | |
---|---|---|
http.createServer | ● | ● |
http.createSubServer | ● | ● |
server.isMaster | ● | ● |
server.groupName | ● | ● |
server.addcert | ● | ● |
server.start | ● | ● |
server.stop | ● | ● |
server.port | ● | ● |
HttpServer Class
The HttpServer inherit from Server. It can be create by createServer
and createSubServer
.
http.createServer(group, handle, subs[, subMode], saddr[, tlsOpt])
group
{String} Server group name(master server module). Usually the module name is used as the group name. If the server work on mult-task mode(subs > 0) andsubMode
is missing, thegroup
must be supported as app module name.handle
{Function} Http request handle function.subs
{Integer} The new task counts, if subs > 0, server run in mult-task.subMode
{String} sub-server module. If the sub-server is the same module as the master-server,subMode
can be defaulted and provided bygroup
. Otherwise,subMode
represents the sub-server module.saddr
{Object} Server socket address. If the port ofsaddr
is set to 0, the setting port will be assigned automatically, and the port can be found throughserver.port()
.tlsOpt
{Object} TLS securely connections options. default: undefined, means use TCP connection.
This method creates a master-server. When the master-server starts, it can create a specified number(subs) of sub-servers (subs), refer to HttpServer mult-task
.
Example
- Create single server:
var HttpServer = require('http').HttpServer;
var saddr = socket.sockaddr(socket.INADDR_ANY, 8000);
var httpSer = HttpServer.createServer('./http_server', function(req, res) {
res.end('hello world.');
}, 0, saddr);
httpSer.start();
- Create mult-task server:
var HttpServer = require('http').HttpServer;
var saddr = socket.sockaddr(socket.INADDR_ANY, 8000);
var httpSer = HttpServer.createServer('./http_server', function(req, res) {
res.end('hello world.');
}, 2, saddr);
httpSer.start();
http.createSubServer(group, handle)
group
{String} Server group name, the same as master-server group name.handle
{Function} Http request handle function.
Use this method to create a sub-server when the sub-server is not on the same module as the master-server.
Example
- Master-server,
./http_mult.js
:
var HttpServer = require('http').HttpServer;
var saddr = socket.sockaddr(socket.INADDR_ANY, 8000);
server = HttpServer.createServer('http_mult', function(req, res) {
res.end(`my ser is: ${server.groupName.name}`);
}, 2, './http_mult_sub', saddr);
server.start();
- Sub-server,
./http_mult_sub.js
:
var HttpServer = require('http').HttpServer;
var server = HttpServer.createSubServer('http_mult', function(req, res) {
res.end(`my ser is: ${server.groupName.name}`);
});
server.start();
HttpServer mult-task
The HttpServer have two work mode:
MASTER
The master-server listens and receives the client request. If the sub server is registered on the master server, the master server will dispatch the request to itself or the sub server for processing.SUB
The sub-server works on a separate task. It does not listen on the port, does not directly accept requests from the client, but accepts requests dispatched by the master-server.
A httpServer can be a single task or multiple tasks(mult-task). When it works in mult-task mode, there is one master-server and several sub-servers, which are created by master-server when the master-server is started. When the master-server is working, the client requests are evenly distributed to all the sub-servers and the master-server itself.
The sub-server can be the same module as the master-server, or it can be a different module. If they are on the same module, you don't need to create a sub-server explicitly. If the sub-server is not on the same module as master-server, user should create it by createSubServer
.
HttpServer Object
server.isMaster()
- Returns: {Boolean} Whether it is the master server.
Get whether the server object is the master server.
server.groupName
groupName
{Object}group
{String} The server group name, seeHttpServer mult-task
.name
{String} The server name, seeHttpServer mult-task
.
server.addcert(opt)
opt
{Object} Tls server option.- Returns: {Boolean} Whether it was added successfully.
opt
includes following items:
name
{String} Server domain name.ca
{String} Optional trusted CA certificates. default: no CA certificates.cert
{String} Server certificate.key
{String} Private key of server certificate.passwd
{String} Private key password. default: no password.
This method adds a SNI (Server Name Indication) certificate to the tls server. SNI is an extension used to improve SSL or TLS for servers. It mainly solves the disadvantage that one server can only use one certificate (one domain name). With the support of the server for virtual hosts, one server can provide services for multiple domain names, so SNI must be supported to meet the demand.
server.start()
- Returns: {Boolean} Server start success or not.
Start http server.
server.stop([stopAll] [, cb])
stopAll
{Boolean} always true forMASTER
mode, close all task servers. ForSUB
mode: true - stop all task servers; false - stop this sub server. default: false.cb
{Function} Callback whenstop
event emit.
Stop http server.
server.port()
- Returns: {Integer | Undefined} Server socket port.
When the server starts with the MASTER
module, server.port()
gets the port of the server, otherwise it returns undefined
.
Example
var port = server.port();
console.log(port);
HttpServer Events
start
Emitted when the http server start done.
stop
Emitted when the http server stop.
request
Emitted when a http request comes to server. It has the following properties:
req
{HttpServerRequest} The http request object, seeHttpServerRequest
.res
{HttpServerResponse} The http response object, seeHttpServerResponse
.
HttpServerRequest Object
HttpServerRequest
inherit from HttpInput
class, see the HttpInput
module for more details: : HttpInput.
request.enableTimeout(enable)
enable
{Boolean} The request session timeout option. default: true.
If request enable timeout (req.enableTimeout(true)
), the server does not track the request session until the client closes the HTTP connection or an exception occurs. Otherwise, the server will trace the request and the server will close the HTTP connection with the request timed out.
Example
req.enableTimeout(false);
request.close()
Close the request session and close HTTP connection.
request.destroy([error])
error
Error which will be passed as payload in'error'
event.- Returns: this.
Close the request session and close HTTP connection.
HttpServerRequest Events
data
When HTTP body is received from the client a data
event is emitted with a buf
object:
buf
{Buffer} Receive from client.
end
When all body data is received or there is no body data a end
event is emitted.
close
A close
event is emitted when the request disconnected. Request may be closed normally or not properly, so the end
event may not be emitted before the close
event.
error
A error
event is emitted when the error occurs.
HttpServerResponse Object
HttpServerResponse
inherit from HttpOutput
class, see the HttpOutput
module for details: HttpOutput.
response.destroy([error])
error
Error which will be passed as payload in'error'
event.- Returns: this.
Close the response session and close HTTP connection.
HttpServerResponse Events
end
A end
event is emitted when the response had been done. The follow method will emitted 'end' event:
res.end()
finish
The output stream finishs. The finish
event is the same as the end
event.
close
A close
event is emitted when the response disconnected. Response may be closed normally or not properly, so the end
or finish
event may not be emitted before the close
event.
error
A close
event is emitted when the error occurs.
drain
If a call to res.write(chunk)
returns false
, the 'drain'
event will be emitted when it is appropriate to resume writing data to the response.
Example
- Base http server
var socket = require('socket');
var HttpServer = require('http').HttpServer;
var iosched = require('iosched');
var saddr = socket.sockaddr(socket.INADDR_ANY, 8000);
var server = HttpServer.createServer('./base_httpserver', function(req, res) {
res.end('Hello world.');
}, 0, saddr);
server.start();
while(true) {
iosched.poll();
}
- Mult-server Http master-server and sub-server the same module:
var socket = require('socket');
var HttpServer = require('http').HttpServer;
var iosched = require('iosched');
var count = 0;
function handle(req, res) {
var content = `
<html>
<head>
<link rel="icon" href="">
</head>
<body>
<H1>This is sub server</H1>
<H2>my ser is: ${server.groupName.name}</H2>
<H2>ser count: ${count++}</H2>
</body>
</html>`;
res.setHeader('Content-Type', 'text/html');
res.end(content);
}
var saddr = socket.sockaddr(socket.INADDR_ANY, 8000);
var server = HttpServer.createServer('./http_multserver', handle, 2, saddr);
server.start();
while(true) {
iosched.poll();
}
Mult-server different module
- master-server module,
./http_mult.JS
:
var socket = require('socket'); var HttpServer = require('http').HttpServer; var iosched = require('iosched'); var count = 0; function handle(req, res) { var content = ` <html> <head> <link rel="icon" href=""> </head> <body> <H1>This is master server</H1> <H2>my ser is: ${server.groupName.name}</H2> <H2>ser count: ${count++}</H2> </body> </html>`; res.setHeader('Content-Type', 'text/html'); res.write(content); res.end(); } var saddr = socket.sockaddr(socket.INADDR_ANY, 8000); var server = HttpServer.createServer('http_mult', handle, 2, './http_mult_sub', saddr); server.start(); while(true) { iosched.poll(); }
- sub-server module,
./http_mult_sub.js
:
var HttpServer = require('http').HttpServer; var iosched = require('iosched'); var count = 0; function handle(req, res) { var content = ` <html> <head> <link rel="icon" href=""> </head> <body> <H1>This is sub server</H1> <H2>my ser is: ${server.groupName.name}</H2> <H2>ser count: ${count++}</H2> </body> </html>`; res.setHeader('Content-Type', 'text/html'); res.end(content); } var server = HttpServer.createSubServer('http_mult', handle); server.start(); while(true) { iosched.poll(); }
- master-server module,