美文网首页
使用cluster模块启动多进程nodejs应用

使用cluster模块启动多进程nodejs应用

作者: caltrop | 来源:发表于2018-03-16 15:06 被阅读0次

使用命令行的方式运行nodejs web应用,一旦程序有bug造成进程崩溃,应用就不能继续提供服务了;并且,nodejs是单线程的模式,不能充分利用服务器的多核资源。使用node的cluster模块可以监控应用进程,退出后重新启动node应用进程,并可以启动多个node应用进程,做到负载均衡,充分利用资源。

启动单个进程

node bin/www

文件www的内容为:


/**
 * @fileOverview 应用程序启动文件入口
 * @author --
 */
"use strict";

const app = require('../app');
const http = require('http');
const logger = require("../logger").appLogger();

/**
 * 设置程序监听端口
 */
let port = normalizePort(config.port || process.env.PORT || '3001');
app.set('port', port);

/**
 * 创建http服务实例
 */
let server = http.createServer(app);

/**
 * 开启服务监听
 */
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);

/**
 * 格式化监听端口
 */
function normalizePort(val) {
    let port = parseInt(val, 10);

    if (isNaN(port)) {
        /** named pipe */
        return val;
    }

    if (port >= 0) {
        /** port number */
        return port;
    }

    return false;
}

/**
 * 启动错误事件处理
 */
function onError(error) {
    if (error.syscall !== 'listen') {
        throw error;
    }

    let bind = typeof port === 'string'
            ? 'Pipe ' + port
            : 'Port ' + port;

    /** 错误提示 */
    switch (error.code) {
        case 'EACCES':
            logger.error(bind + ' 权限不足');
            process.exit(1);
            break;
        case 'EADDRINUSE':
            logger.error(bind + ' 端口被占用');
            process.exit(1);
            break;
        default:
            throw error;
    }
}

/**
 * 正常启动事件处理
 */
function onListening() {
    let addr = server.address();
    let bind = typeof addr === 'string'
            ? 'pipe ' + addr
            : 'port ' + addr.port;
    logger.info('服务启动成功');
    logger.info('Listening on ' + bind);
}

cluster多进程模式

node bin/cluster.js

文件cluster.js的内容为:


/**
 * @fileOverview 应用程序多进程启动入口
 * @author --
 */
"use strict";

const cluster = require('cluster');
const cpus = require('os').cpus();

const accessLogger = require("../logger").accessLogger();

accessLogger.info('master ' + process.pid + ' is starting.');

cluster.setupMaster({
    /* 应用进程启动文件 */
    exec: 'bin/www'
});

/* 启动应用进程个数和服务器CPU核数一样 */
for (let i = 0; i < cpus.length; i++) {
    cluster.fork();
}

cluster.on('online', function (worker) {
    /* 进程启动成功 */
    accessLogger.info('worker ' + worker.process.pid + ' is online.');
});
cluster.on('exit', function (worker, code, signal) {
    /* 应用进程退出时,记录日志并重启 */
    accessLogger.info('worker ' + worker.process.pid + ' died.');
    cluster.fork();
});

其他多进程方案

直接使用cluster模块管理nodejs进程,要在生产环境中使用,还要做很多工作,属于重复造轮子。现在比较流行的nodejs进程监控和多进程管理的工具有supervisor、forever、pm2等,下一篇将就pm2和docker谈一谈nodejs web应用在生产环境中的部署

相关文章

  • 使用cluster模块启动多进程nodejs应用

    使用命令行的方式运行nodejs web应用,一旦程序有bug造成进程崩溃,应用就不能继续提供服务了;并且,nod...

  • node 多进程与session共享

    一、Node如何开启多进程 cluster是一个nodejs内置的模块,用于nodejs多核处理。cluster模...

  • nodejs cluster

    nodejs集群可以使用cluster模块, if (cluster.isMaster) { // Fork wo...

  • nodejs 多进程篇

    nodejs 多进程篇 子进程创建模块 child_process spawn() : 启动一个子进程用来执行命令...

  • Nodejs cluster 模块

    cluster 和 child_process 模块子进程的区别 child_process 执行 shell 命...

  • Android 进程相关——学习笔记

    一:多进程的作用 1:多进程主要用于实现应用的多模块化,使一个应用分解为多个子项模块,方便控制与使用。2:多进程还...

  • forever

    使用forever运行nodejs应用何为forever forever可以看做是一个nodejs的守护进程,能够...

  • python多进程与linux任务调度的困惑

    现象: 使用python的multiprocessing多进程模块,启动了100个进程去使用pyhdfs库对hdf...

  • skynet cluster学习笔记一

    skynet的cluster模式官方WIKI介绍cluster模块把不同IP上的不同进程或者同一IP上的不同进程联...

  • 使用forever运行nodejs应用

    何为forever forever可以看做是一个nodejs的守护进程,能够启动,停止,重启我们的app应用。官方...

网友评论

      本文标题:使用cluster模块启动多进程nodejs应用

      本文链接:https://www.haomeiwen.com/subject/xctrqftx.html