同一应用程序中的Express和Cluster节点模块

时间:2015-02-11 12:53:22

标签: node.js express node-cluster

我正在创建一个应用程序,允许用户将浏览器中的文件上传到服务器。

我是通过在项目文件夹中输入express开始的。随着快递创建了所有的文件夹等。它创建了一个bin文件夹,其中包含一个www文件,可以为我们启动很多东西,比如ports。

起初我只有一个核心,所以我这样做:

var express = require('express');

var multer = require('multer');

var app = express();

var done = false;
var fileSize = 0;

app.use(multer({ dest: './uploads/',
    rename: function (fieldname, filename){
        return filename;
    },
    onFileUploadStart: function(file){
        console.log(file.originalname + ' is starting...');
    },
    onFileUploadComplete: function(file){
        console.log(file.fieldname + ' uploaded to ' + file.path);
        done = true;
    },
    onFileUploadData: function(file, data){
        fileSize += data.length;
        console.log("FileUpload " + fileSize);
    }
}));

app.get('/', function(request, response){
    response.sendFile(__dirname + '/index.html');
});

app.post('/upload/', function(request, response){
    console.log(request.body);
    if (done == true)
        response.end('file uploaded');
});
module.exports = app;

最终我需要使用具有多个内核的计算机,以便能够响应更多客户端请求。所以我正在尝试使用集群模块。

我相应地更改了代码:

var cluster = require('cluster');

if(cluster.isMaster){
    var numCPUS = require('os').cpus().length;
    for(var i=0; i<numCPUS; i++)
        cluster.fork();

    cluster.on('exit', function(worker, code, signal) {
        console.log('worker ' + worker.process.pid + ' died');
    });

    cluster.on('online', function(worker) {
        console.log('worker ' + worker.process.pid + ' started');
    });

}else{
    var express = require('express');
    var multer = require('multer');

    var app = express();

    var done = false;
    var fileSize = 0;

    app.use(multer({ dest: './uploads/',
        rename: function (fieldname, filename){
            return filename;
        },
        onFileUploadStart: function(file){
            console.log(file.originalname + ' is starting...');
        },
        onFileUploadComplete: function(file){
            console.log(file.fieldname + ' uploaded to ' + file.path);
            done = true;
        },
        onFileUploadData: function(file, data){
            fileSize += data.length;
            console.log("FileUpload " + fileSize);
        }
    }));

    app.get('/', function(request, response){
        response.sendFile(__dirname + '/index.html');
    });

    app.post('/upload/', function(request, response){
        console.log(request.body);
        if (done == true)
            response.end('file uploaded');
    });
    module.exports = app;
}

问题是,当我这样做时,我在控制台中收到以下错误:

运行:node ./bin/www 结果:

app.set('port', port);

TypeERror: Cannot call method 'set' of undefined at Object.<anonymous> 

这是因为我将整个代码放在master的forked子节点中。任何人都知道为什么会这样,以及我如何解决它?

修改 在这里,您可以看到bin / www文件,其中设置了端口和一些其他配置:

#!/usr/bin/env node

/**
 * Module dependencies.
 */

var app = require('../app');
var debug = require('debug')('dropbox:server');
var http = require('http');

/**
 * Get port from environment and store in Express.
 */

var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);

/**
 * Create HTTP server.
 */

var server = http.createServer(app);

/**
 * Listen on provided port, on all network interfaces.
 */

server.listen(port);
server.on('error', onError);
server.on('listening', onListening);

/**
 * Normalize a port into a number, string, or false.
 */

function normalizePort(val) {
  var port = parseInt(val, 10);

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

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

  return false;
}

/**
 * Event listener for HTTP server "error" event.
 */

function onError(error) {
  if (error.syscall !== 'listen') {
    throw error;
  }

  var bind = typeof port === 'string'
    ? 'Pipe ' + port
    : 'Port ' + port

  // handle specific listen errors with friendly messages
  switch (error.code) {
    case 'EACCES':
      console.error(bind + ' requires elevated privileges');
      process.exit(1);
      break;
    case 'EADDRINUSE':
      console.error(bind + ' is already in use');
      process.exit(1);
      break;
    default:
      throw error;
  }
}

/**
 * Event listener for HTTP server "listening" event.
 */

function onListening() {
  var addr = server.address();
  var bind = typeof addr === 'string'
    ? 'pipe ' + addr
    : 'port ' + addr.port;
  debug('Listening on ' + bind);
}

0 个答案:

没有答案