node 多進程與session共享

一纺腊、Node如何開啟多進程

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

我的系統(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

控制臺打哟伟薄:

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

2.cluster API

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

worker對象的各種屬性和函數(shù):可以通過cluster.workers, cluster.worket獲得蔽介。
worker.id: 進程ID號
worker.process: ChildProcess對象
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(): 斷開worker連接,讓worker自殺
Event: 'message': 監(jiān)聽master和worker的message事件
Event: 'online': 監(jiān)聽指定的worker創(chuàng)建成功事件
Event: 'listening': 監(jiān)聽master向worker狀態(tài)事件
Event: 'disconnect': 監(jiān)聽worker斷線事件
Event: 'exit': 監(jiān)聽worker退出事件

二幸撕、多進程間如何共享session

關(guān)于session共享有這么幾種做法:
進程通信薇组、redis存儲、本地mongodb存儲坐儿、數(shù)據(jù)庫存儲律胀。
本篇使用的是redis來存儲session,node提供了connect-redis模塊用來連接redis數(shù)據(jù)庫貌矿。

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);

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末逛漫,一起剝皮案震驚了整個濱河市黑低,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌酌毡,老刑警劉巖克握,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蕾管,死亡現(xiàn)場離奇詭異,居然都是意外死亡菩暗,警方通過查閱死者的電腦和手機娇掏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來勋眯,“玉大人婴梧,你說我怎么就攤上這事】吞#” “怎么了塞蹭?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長讶坯。 經(jīng)常有香客問我番电,道長,這世上最難降的妖魔是什么辆琅? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任漱办,我火速辦了婚禮,結(jié)果婚禮上婉烟,老公的妹妹穿的比我還像新娘娩井。我一直安慰自己,他們只是感情好似袁,可當(dāng)我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布洞辣。 她就那樣靜靜地躺著,像睡著了一般昙衅。 火紅的嫁衣襯著肌膚如雪扬霜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天而涉,我揣著相機與錄音著瓶,去河邊找鬼。 笑死啼县,一個胖子當(dāng)著我的面吹牛材原,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播谭羔,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼华糖,長吁一口氣:“原來是場噩夢啊……” “哼麦向!你這毒婦竟也來了瘟裸?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤诵竭,失蹤者是張志新(化名)和其女友劉穎话告,沒想到半個月后兼搏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡沙郭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年佛呻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片病线。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡吓著,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出送挑,到底是詐尸還是另有隱情绑莺,我是刑警寧澤,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布惕耕,位于F島的核電站纺裁,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏司澎。R本人自食惡果不足惜欺缘,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望挤安。 院中可真熱鬧谚殊,春花似錦、人聲如沸蛤铜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昂羡。三九已至絮记,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間虐先,已是汗流浹背怨愤。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蛹批,地道東北人撰洗。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像腐芍,于是被迫代替她去往敵國和親差导。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,843評論 2 354

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