一、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ì)丟失。