位置: 编程技术 - 正文

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)

  • 企业所得税怎么算出来
  • 一个月没有账务往来,现金日记账如何登记?
  • 发票可不可以盖财务专用章
  • 金蝶标准版如何结转到下月
  • 2019年小规模纳税人增值税优惠
  • 符合条件的居民企业之间股息红利
  • 填写三季度预缴所得税申报表应关注哪些事项
  • 小规模纳税人免税会计分录
  • 收到政府补助的固定资产的账务处理
  • 预缴增值税为什么记借方
  • 当月发票入库核销怎么算
  • 申报增值税附表二代不出数据
  • 生活支出计入什么科目
  • 会议费税前扣除标准2021
  • 技术转让开具什么发票
  • 电子发票隔月可以报销吗
  • 公司招待用烟酒的管理
  • 申报个税按计提工资还是实际发放
  • 1697508857
  • 债券回购的含义和种类
  • 分期收款什么是分期还款
  • 耕地建厂房补偿方法
  • 一般纳税人进项税会计分录
  • 土地增值税的土地成本要扣除增值税吗
  • win11windows键没反应
  • 施工企业会计制度有哪些
  • 行政单位上年支出退回
  • 尚未支付的货款属于什么会计要素
  • php接收数据的方法
  • 外币交易犯法吗
  • 偷税漏税的会计要负什么责任
  • encore是什么软件
  • 国有资产无偿使用违反什么规定
  • bestars皮纳
  • php数组函数面试题
  • 税金及附加和营业收入有关系吗
  • JavaScript(WebAPI)+具体案例
  • 如何使用axios直接发送GET请求
  • opencv 方框识别
  • 固定资产改造更新
  • 应收账款提了坏账后收回
  • 弃置费用预计负债的摊余成本
  • 农民工工资专用账户
  • 应付职工薪酬住房公积金怎么算
  • 桥接模式例题
  • 科技局创业扶持资金
  • 小规模纳税人的增值税怎么算
  • 材料暂估入库的附件需要哪些资料
  • 发票系统怎么用
  • 金税盘的维护费怎么报税
  • 收到房租租金下什么科目
  • 房地产开发企业分为几个等级
  • 进口产品内销如何交税
  • 内退文件2018
  • 一般纳税人出现以下哪些情况时,其进项税额不得抵扣( )
  • 非流动资产减少
  • 明细分类账的格式与登记方法
  • 咨询费计入什么明细科目
  • 企业如何进行年报
  • win10 tab alt
  • windowsserver2008r2激活密钥
  • 局域网 下载
  • 如何重设路由器密码怎么办
  • windows 8.1 with update
  • mac休眠怎么设置
  • unity outline性能
  • win7安装要求配置
  • cocos2dx3.2 xcode中资源路径设置问题
  • jquery删除当前元素
  • shell脚本批处理
  • cd跳转不到目录
  • 将bat文件注册为应用程序
  • android之handler
  • jQueryUI Datepicker组件设置日期高亮
  • node如何使用
  • 安卓多线程有几种实现方法
  • jquery获取当前元素是第几个元素
  • 开票网线属于哪一类
  • 税务查询热线
  • 车辆免征信息怎么查
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设