Sample Code.

Express와 같이 사용 하였다.

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path');

var app = express();

var cluster = require('cluster')
  , numCPUs = require('os').cpus().length;

function setting() {
  app.configure(function(){
    app.set('port', process.env.PORT || 3000);
    app.set('views', __dirname + '/views');
    app.set('view engine', 'ejs');
    app.use(express.favicon());
    app.use(express.logger('dev'));
    app.use(express.bodyParser());
    app.use(express.methodOverride());
    app.use(express.cookieParser('your secret here'));
    app.use(express.session());
    app.use(app.router);
    app.use(express.static(path.join(__dirname, 'public')));
  });

  app.configure('development', function(){
    app.use(express.errorHandler());
  });

  app.get('/', routes.index);
  app.get('/users', user.list);

  http.createServer(app).listen(app.get('port'), function(){
    console.log("Express server listening on port " + app.get('port'));
  });
}

function eachWorker(callback) {
  for (var id in cluster.workers) {
    callback(cluster.workers[id]);
  }
}

// master
if (cluster.isMaster) {
  for (var i=0; i<numCPUs; i++) {
    var worker = cluster.fork();

    worker.on('message', function(message) {
      if (message.cmd == 'broadcast') {
        console.log('send worker');

        setInterval(function() {
          eachWorker(function(_worker) {
            _worker.send({ cmd: 'broadcast', message: 'test message' });
          })
        }, 1000);
      }
    });
  }

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

// worker
} else {
  if (cluster.isWorker) {
    console.log(' I am worker ' + cluster.worker.id);

    process.on('message', function(message) {
      if (message.cmd == 'broadcast') {
        console.log('receive message: ' + message.message);
      }
    });

    process.send({ cmd: 'broadcast' });
  }
}

1.1  Master (Parent)

부모 프로세스 로 볼 수 있으며 자식 프로세스를 생성 한다. 위 코드를 참고 시 'broadcast' 라는 명령어로 event 감지 하여 데이터를 주고 받는다.


1.2  Worker (Child)

부모 프로세스 가 fork() 할 경우 생성 된다. 해당 프로세스는 생성 되는 시점에서 'message' 라고 명령어를 보낸다.


1.3  Test 

sample를 실행해 보자.


whitelife@whitelife:~/work/cluster_test$ node app.js 

 I am worker #1

send worker.....

 I am worker #2

send worker.....

receive message: test message

receive message: test message


※ 참고 사이트

  - node api: http://www.nodejs.org/api/cluster.html


+ Recent posts