位置: 编程技术 - 正文

node 利用进程通信实现Cluster共享内存(node 线程 进程)

编辑:rootadmin

推荐整理分享node 利用进程通信实现Cluster共享内存(node 线程 进程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node子进程,node子进程,node 线程 进程,node多进程,node获取某个进程pid,node进程通信,node 进程管理,node子进程,内容如对您有帮助,希望把文章链接给更多的朋友!

Node.js的标准API没有提供进程共享内存,然而通过IPC接口的send方法和对message事件的监听,就可以实现一个多进程之间的协同机制,通过通信来操作共享内存。

##IPC的基本用法:

在Node.js中,通过send和on(‘message', callback)实现的IPC通信有几个特点。首先,master和worker之间可以互相通信,而各个worker之间不能直接通信,但是worker之间可以通过master转发实现间接通信。另外,通过send方法传递的数据,会先被JSON.stringify处理后再传递,接收后会再用JSON.parse解析。所以Buffer对象传递后会变成数组,而function则无法直接传递。反过来说,就是可以直接传递除了buffer和function之外的所有数据类型(已经很强大了,而且buffer和function也可以用变通的方法实现传递)。

基于以上特点,我们可以设计一个通过IPC来共享内存的方案:

1、worker进程作为共享内存的使用者,并不直接操作共享内存,而是通过send方法通知master进程进行写入(set)或者读取(get)操作。

2、master进程初始化一个Object对象作为共享内存,并根据worker发来的message,对Object的键值进行读写。

3、由于要使用跨进程通信,所以worker发起的set和get都是异步操作,master根据请求进行实际读写操作,然后将结果返回给worker(即把结果数据send给worker)。

node 利用进程通信实现Cluster共享内存(node 线程 进程)

##数据格式

为了实现进程间异步的读写功能,需要对通信数据的格式做一点规范。

首先是worker的请求数据:

master在接到数据后,会根据method执行相应操作,然后根据requestMessage.id将结果数据发给对应的worker,数据格式如下:

规范数据格式的意义在于,master在接收到请求后,能够将处理结果发送给对应的worker,而worker在接到回传的结果后,能够调用此次通信对应的callback,从而实现协同。

规范数据格式后,接下来要做的就是设计两套代码,分别用于master进程和worker进程,监听通信并处理通信数据,实现共享内存的功能。

##User类

User类的实例在worker进程中工作,负责发送操作共享内存的请求,并监听master的回信。

##Manager类

Manager类的实例在master进程中工作,用于初始化一个Object作为共享内存,并根据User实例的请求,在共享内存中增加键值对,或者读取键值,然后将结果发送回去。

##使用方法

标签: node 线程 进程

本文链接地址:https://www.jiuchutong.com/biancheng/368541.html 转载请保留说明!

上一篇:基于Datatables跳转到指定页的简单实例(datatable.load)

下一篇:Express系列之multer上传的使用(express model)

  • 没有独立核算的分公司需要报税
  • 个税系统经营所得如何添加人员信息
  • 其他综合收益税后
  • 专票丢失登报后怎么处理
  • 应付账款的核算会计分录
  • 房产税计税依据
  • 差额征税的财税处理怎么做?
  • 坏账准备的账务处理怎么理解
  • 应付税费包括
  • 网银 密码器
  • 包工不包料会计处理
  • 企业固定资产的盘亏净损失
  • 坏账核销谁来审批
  • 筹建期水电费计入什么科目
  • 票据结算包括哪几项
  • 1697508645
  • 转出未交增值税科目
  • 延期申报出口退税流程
  • 取得劳务收入的会计分录
  • 英雄联盟中该如何加好友
  • 在windows七中
  • 暂估成本的会计处理
  • 出口转内销发票抵扣
  • php?ms=0&qgg=&_wv=3
  • PHP:xml_set_notation_decl_handler()的用法_XML解析器函数
  • thinkphp d方法
  • php实现的mongodb操作类实例
  • 结转损益和结转成本
  • Win10 20H1/20H2 KB5001391补丁今日发布(内附下载)
  • 其它业务收入是什么科目
  • 融资租赁与经营租赁的联系
  • postman汉化包
  • 购买材料支出明细表
  • tensorflow gpu安装
  • vue接入高德地图
  • 旅游公司差额征税税率是5%
  • 资产账面价值大于计税基础产生递延所得税负债
  • 培训机构先收费后付费
  • 先款还是先票
  • 小规模纳税人代收水电费税率
  • 资产负债表中应付账款项目应根据什么填制
  • access宏操作
  • 织梦建站详细教程
  • 怎么做零售企业
  • 餐饮业会计做账怎么做
  • 建账的三个基本步骤
  • 2023小型微利企业税收优惠
  • 矿产资源补偿费计入管理费用吗
  • 购销合同没注明合同有效期
  • 息税前利润变动率的计算公式
  • 公司租赁房屋房产税
  • 生产车间人员工资期末结转
  • 原材料不足
  • 不是销售性质的工作
  • 其他人挂靠公司交社保会计处理怎么做?
  • 水果销售公司怎么起名字好听
  • 旅行社滞纳金计算公式
  • 通信费抬头为个人
  • 应收会计怎么做
  • 买入返售金融资产 流动资产
  • sqlserverssms
  • innodb底层实现原理
  • win7自动变成win10
  • windows mobile应用下载
  • windows 2008
  • win7出现正在启动就不动了
  • win7进运行
  • win8打开cmd的快捷键
  • linux root用户登陆
  • 安卓获取设备信息
  • linux tcp keepalive
  • python中pillow模块
  • perl 正则表达式 保留原有字符
  • 查找重复字符串
  • core文件的作用
  • js根据对象的key来获取对应值
  • 用python定义一个函数
  • jquery插件免费下载
  • 农业银行联行号查询系统官网
  • 国税地税征管体制改革方案
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设