node 多進(jìn)程與session共享

一、Node如何開(kāi)啟多進(jìn)程

cluster是一個(gè)nodejs內(nèi)置的模塊,用于nodejs多核處理。cluster模塊,可以幫助我們簡(jiǎn)化多進(jìn)程并行化程序的開(kāi)發(fā)難度,輕松構(gòu)建一個(gè)用于負(fù)載均衡的集群。

我的系統(tǒng)環(huán)境:

  • OS X Yosemite 10.10.5
  • node V4.4.3
  • npm V2.15.1

1. cluster 示例

新建文件夾

$ mkdir test_cluster && cd test_cluster

創(chuàng)建app.js

$ vim app.js
var cluster =require('cluster');
var http =require('http');
var processes = 4;
if(cluster.isMaster) {
  console.log("master start...");
  //Fork workers.
  for(var i =0; i < processes; i++) {
    cluster.fork();
  }
  cluster.on('listening',function(worker,address){
    console.log('listening: worker '+ worker.process.pid);
  });
  cluster.on('exit', function(worker, code, signal) {
    console.log('worker '+ worker.process.pid +' died');
  });
}else{
  http.createServer(function(req, res) {
    res.writeHead(200);
    res.end("server start!");
  }).listen(3000);
}
$ node app.js

控制臺(tái)打?。?/p>

master start...
listening: worker 92753
listening: worker 92754
listening: worker 92755
listening: worker 92756

2.cluster API

cluster對(duì)象的各種屬性和函數(shù)
cluster.setttings:配置集群參數(shù)對(duì)象
cluster.isMaster:判斷是不是master節(jié)點(diǎn)
cluster.isWorker:判斷是不是worker節(jié)點(diǎn)
Event: 'fork': 監(jiān)聽(tīng)創(chuàng)建worker進(jìn)程事件
Event: 'online': 監(jiān)聽(tīng)worker創(chuàng)建成功事件
Event: 'listening': 監(jiān)聽(tīng)worker向master狀態(tài)事件
Event: 'disconnect': 監(jiān)聽(tīng)worker斷線事件
Event: 'exit': 監(jiān)聽(tīng)worker退出事件
Event: 'setup': 監(jiān)聽(tīng)setupMaster事件
cluster.setupMaster([settings]): 設(shè)置集群參數(shù)
cluster.fork([env]): 創(chuàng)建worker進(jìn)程
cluster.disconnect([callback]): 關(guān)閉worket進(jìn)程
cluster.worker: 獲得當(dāng)前的worker對(duì)象
cluster.workers: 獲得集群中所有存活的worker對(duì)象

worker對(duì)象的各種屬性和函數(shù):可以通過(guò)cluster.workers, cluster.worket獲得。
worker.id: 進(jìn)程ID號(hào)
worker.process: ChildProcess對(duì)象
worker.suicide: 在disconnect()后,判斷worker是否自殺
worker.send(message, [sendHandle]): master給worker發(fā)送消息。注:worker給發(fā)master發(fā)送消息要用process.send(message)
worker.kill([signal='SIGTERM']): 殺死指定的worker,別名destory()
worker.disconnect(): 斷開(kāi)worker連接,讓worker自殺
Event: 'message': 監(jiān)聽(tīng)master和worker的message事件
Event: 'online': 監(jiān)聽(tīng)指定的worker創(chuàng)建成功事件
Event: 'listening': 監(jiān)聽(tīng)master向worker狀態(tài)事件
Event: 'disconnect': 監(jiān)聽(tīng)worker斷線事件
Event: 'exit': 監(jiān)聽(tīng)worker退出事件

二、多進(jìn)程間如何共享session

關(guān)于session共享有這么幾種做法:
進(jìn)程通信、redis存儲(chǔ)、本地mongodb存儲(chǔ)、數(shù)據(jù)庫(kù)存儲(chǔ)。
本篇使用的是redis來(lái)存儲(chǔ)session,node提供了connect-redis模塊用來(lái)連接redis數(shù)據(jù)庫(kù)。

var express = require('express');
var session = require('express-session');
var RedisStore=require('connect-redis')(session);
var app = express();

// 本地redis配置參數(shù)
var options = {
  host:'127.0.0.1',
  port:'6379',
  db:0
};

app.use(session({
  secret: 'secret-string',
  saveUninitialized:true,
  resave:false,
  store:newRedisStore(options)
}));

app.get("/", function(req, res) {
  var session = req.session;session.count = session.count ||0;
  var n = session.count++;
  res.send('hello, session id:'+ session.id +' count:'+ n);
});

app.listen(3000);

通過(guò)應(yīng)用redis就可以保證各進(jìn)程使用的session是一致的了。即使進(jìn)程崩潰也能保證用戶的登錄狀態(tài)不會(huì)丟失。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容