博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
master + worker模式的node多核解决框架——node-cluster
阅读量:6105 次
发布时间:2019-06-21

本文共 2571 字,大约阅读时间需要 8 分钟。

master + worker模式的node多核解决框架——node-cluster

还在为node运行于单进程而苦恼么?即便是node本身提供了cluster功能,或者在github和npm上有很多优秀的模块帮你做封装,但你仍然逃避不掉这些问题:

  1. 性能问题;
  2. 多进程worker的存活状态管理;
  3. 服务的平滑重启;
  4. 配置或者静态数据的动态reload.

我相信你完全有能力把这些事情做得很好。但在自己动手之前,为何不尝试一下node-cluster呢?

node-cluster只有一个文件,区区500多行代码(包括注释),为你解决了上面的所有问题。利用node-cluster构建你的多进程服务非常简单:

  1. 在master进程中,你只需要5行代码:

    var cluster = require('node-cluster');var master = new cluster.Master();master.register(8080, 'app.js');master.dispatch();
  2. 在worker进程中,你只需要关心你的app逻辑即可。一个基于HTTP协议的典型例子如下:

    var Http  = require('http');var cluster = require('node-cluster');var admin  = new cluster.Worker();var server  = Http.createServer(function (req, res) {
    admin.transact(); res.writeHead(200, {
    'Content-Type': 'text/plain;charset=utf-8'}); res.end('hello world'); admin.release();});admin.ready(function (socket) {
    server.emit('connection', socket);});

实际上,我设计node-cluster的初衷可不只是这点用途。糯米们都能发掘出哪些应用场景呢?

标签:

在 2012-2-1 21:13发布

在 2012-2-2 10:22重新编辑

 

8 回复

#1

期待性能数据!

在 2012-2-2 00:42回复

 

 

#2

在一台超线程可见 5 * Intel(R) Xeon(R) CPU E5620 @ 2.40GHz 的虚拟机上用siege2.7本机压测,demo/main.js 下的33749端口,与node原生的http模块进行对比。由于基本不涉及IO操作,保证压测时工作进程CPU吃满,结果如下:

*connection: keep-alive模式下(长连接):siege -b -c2 -t1m *

  1. 原生HTTP,时长59.76s,QPS:8486.93,请求数507179,可用率100.00%;
  2. node-cluster,时长59.64s,QPS:8424.51,请求数502438,可用率100.00%;

*connection: close模式下(短连接):siege -b -c1000 *

  1. 原生HTTP,时长24.15s,QPS:4907.33,请求数118512,可用率99.93%;
  2. node-cluster,时长20.71s,QPS:3864.61,请求数80036,可用率100.00%;

结论如下:

  1. 长连接模式下HTTP协议无性能损失。这个容易理解,一旦连接建立,之后的请求就与master无关了;

  2. 短连接模式下,node-cluster封装之后有20%的QPS损失。在短连接模式下,操作系统的文件句柄数首先达到瓶颈。在测试之前,手工通过ulimit -n调整 max opend files为65535,并且在TIME_WAIT状态的TCP连接数小于100的情况下开始压测。

  3. 普遍而言,node的HTTP模块在短连接模式下,比长连接有接近50%的QPS损失。这一点要根据node的使用场景来判断用那种模式。在node做中间层服务时,我们建议采用keep-alive方式。

在 2012-2-2 08:13回复

 

 

#3

话说虚拟机真弱啊,在我的mac上,上边的测试,轻轻松松抛出两倍的QPS

在 2012-2-2 09:13回复

 

{2}

 

mac上的文件句柄数设置搞掂了?

在 2012-2-2 10:00回复

 

 

大概搞掂了,用的zsh,ulimit -n 就可以

在 2012-2-2 10:23回复

 

 

#4

admin. transact()admin.release() 要使用者自行判断在那里调用?这样的使用体验不好啊。

应该让用户对这些没感觉才好,让他们使用起来就像普通的处理逻辑一样。

在 2012-2-2 10:13回复

 

{1}

 

要是不想要平滑重启,能容忍少量的请求丢失,那么不要调这两个方法也可以

在 2012-2-2 10:24回复

 

 

#5

@

function listenAt(obj, port) {
var server = new TCP(); server.bind('0.0.0.0', port); server.listen('/dev/null');

server.listen('/dev/null'); 有具体含义吗?

在 2012-2-13 17:42回复

 

{1}

 

没啥意义

在 2012-2-15 10:17回复

 

 

#6

@ 同求解 :)

在 2012-2-13 22:54回复

 

 

#7

我想问下,多进程内存共享后台有自动同步吗?比如我想同步一些json数据,但是又不想借助如redis,mongodb等的第三方缓存。

在 2012-2-14 10:23回复

 

{1}

 

木有的,数据量大的话我还是建议用这些东西共享

在 2012-2-15 10:18回复

 

 

#8

master.register(8080, 'app.js');

我想添加的是unix socket file,这个能做到吗,就是结合socket和node-cluster

转载地址:http://diaza.baihongyu.com/

你可能感兴趣的文章
B1010.一元多项式求导(25)
查看>>
10、程序员和编译器之间的关系
查看>>
前端学习之正则表达式
查看>>
配置 RAILS FOR JRUBY1.7.4
查看>>
AndroidStudio中导入SlidingMenu报错解决方案
查看>>
修改GRUB2背景图片
查看>>
Ajax异步
查看>>
好记性不如烂笔杆-android学习笔记<十六> switcher和gallery
查看>>
JAVA GC
查看>>
codeforce 599B Spongebob and Joke
查看>>
3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)
查看>>
9、Dubbo-配置(4)
查看>>
前端第七天
查看>>
BZOJ 2190[SDOI2008]仪仗队
查看>>
图解SSH原理及两种登录方法
查看>>
[转载] 七龙珠第一部——第058话 魔境圣地
查看>>
【总结整理】JQuery基础学习---样式篇
查看>>
查询个人站点的文章、分类和标签查询
查看>>
基础知识:数字、字符串、列表 的类型及内置方法
查看>>
JSP的隐式对象
查看>>