国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

node.js中cluster的使用教程

2019-11-19 16:23:05
字體:
來源:轉載
供稿:網友

本文主要給大家介紹了關于node.js中cluster使用的相關教程,分享出來供大家參考學習,下面來看看詳細的介紹:

一、使用NODE中cluster利用多核CPU

var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; if (cluster.isMaster) { // 創建工作進程 for (var i = 0; i < numCPUs; i++) { cluster.fork(); } cluster.on('death', function(worker) { console.log('worker ' + worker.pid + ' died'); cluster.fork();//重啟子進程 }); } else { // 工作進程創建http 服務器 http.Server(function(req, res) { res.writeHead(200); res.end("hello world/n"); }).listen(8000); } 

二、通過消息傳遞來監控工作進程狀態

var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; var rssWarn = (12 * 1024 * 1024)   , heapWarn = (10 * 1024 * 1024) if(cluster.isMaster) {   for(var i=0; i<numCPUs; i++) {     var worker = cluster.fork();     worker.on('message', function(m) {       if (m.memory) {         console.log(m.memory.rss,rssWarn)         if(m.memory.rss > rssWarn) {           console.log('Worker ' + m.process + ' using too much memory.')         }       }      })   } } else { // 服務器   http.createServer(function(req,res) {     res.writeHead(200);     res.end('hello world/n')   }).listen(8000) // 每秒報告一次狀態   setInterval(function report(){     process.send({memory: process.memoryUsage(), process: process.pid});   }, 1000) } 

三、殺死僵尸進程

var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; var rssWarn = (50 * 1024 * 1024)   , heapWarn = (50 * 1024 * 1024) var workers = {} if(cluster.isMaster) {   for(var i=0; i<numCPUs; i++) {     createWorker()   }   setInterval(function() {     var time = new Date().getTime()     for(pid in workers) {       if(workers.hasOwnProperty(pid) &&         workers[pid].lastCb + 5000 < time) {         console.log('Long running worker ' + pid + ' killed')         workers[pid].worker.kill()         delete workers[pid]         createWorker()       }     }   }, 1000) } else { // 服務器   http.Server(function(req,res) { // 打亂200 個請求中的1 個     if (Math.floor(Math.random() * 200) === 4) {       console.log('Stopped ' + process.pid + ' from ever finishing')       while(true) { continue }     }     res.writeHead(200);     res.end('hello world from ' + process.pid + '/n')   }).listen(8000) // 每秒鐘報告一次狀態   setInterval(function report(){     process.send({cmd: "reportMem", memory: process.memoryUsage(),       process: process.pid})   }, 1000) } function createWorker() {   var worker = cluster.fork()   console.log('Created worker: ' + worker.pid) // 允許開機時間   workers[worker.pid] = {worker:worker, lastCb: new Date().getTime()-1000}   worker.on('message', function(m) {     if(m.cmd === "reportMem") {       workers[m.process].lastCb = new Date().getTime()       if(m.memory.rss > rssWarn) {         console.log('Worker ' + m.process + ' using too much memory.')       }     }   }) } 

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永嘉县| 海伦市| 于都县| 青冈县| 鄂伦春自治旗| 肃北| 绥宁县| 安新县| 肥东县| 东安县| 镇沅| 石渠县| 海晏县| 阜康市| 合水县| 甘洛县| 阿荣旗| 嘉义市| 安龙县| 芒康县| 蒙自县| 新邵县| 马山县| 海淀区| 通州市| 贺州市| 肇源县| 南澳县| 荣成市| 柞水县| 盘锦市| 文成县| 轮台县| 阿勒泰市| 都匀市| 郎溪县| 田林县| 泽库县| 曲靖市| 衡东县| 衡东县|