位置: 编程技术 - 正文

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)

  • 年报补交企业所得税如何写会计分录
  • 材料抵扣货款怎么写简单协议范本
  • 进出口税则是什么意思
  • 税收广度
  • 应交增值税二级科目借贷方向
  • 个人工作室需要注册资金吗
  • 个人名字的话费能做账吗
  • 基本账户转到一类卡
  • 暂估入库原材料成本结转后期发票到怎么处理
  • 企业破产时下列受偿等级最高的是
  • 企业所得税应税所得率
  • 收到政府给的公维基金怎么开票报销
  • 个人转让商铺个人所得税核定征收
  • 收到对方开错的发票怎么处理
  • 企业税收滞纳金计入什么科目
  • 研发支出是什么性质的科目
  • 厂开办期间的工作有哪些
  • 技术服务合同增值税免税吗
  • 我的初级备考经历作文
  • 复合增长率什么函数
  • 机器人销售属于什么行业
  • 红字增值税发票含税吗
  • 房屋大修理费用指哪些
  • win11我的电脑不在桌面显示
  • 小微企业 记账
  • linux 网络故障
  • office进程
  • 应交税金的会计科目
  • cuda运行环境
  • 天堂之路歌曲
  • 应交增值税明细科目怎么看
  • 数据结构考试内容
  • php是面向过程还是面向对象
  • 车船税发票丢失
  • php提交表单数据有哪几种方法
  • 自己的智能ai聊天怎么用
  • vue3引入图片
  • java开发从入门到精通
  • python获取值对应的键
  • 个税计税周期 一年
  • 金蝶k3固定资产如何入账
  • 推广服务费可以抵扣吗
  • 百旺连接服务器失败,是否使用离线文件进行更新
  • 公司收到保险公司退保费怎么账务处理
  • 无形资产出租如何入账
  • sql2008附加数据库
  • 综合所得减除费用标准为60000.00元/年
  • 应收款和实收款区别
  • 其他应收款在借方怎么调账
  • 主播工资不发应该到哪里投诉
  • 文化传媒公司的主营业务
  • 其他应收款余额在借方是什么意思
  • 业务招待费可以结转下年抵扣吗
  • 收到质保金怎么写收据
  • 本期盈余为负数怎么调整
  • 进项税额转出的几种情况
  • 物料损失怎么入账
  • 年终结账账务处理
  • 银行存款实际余额不足
  • 个体户不交税会判刑吗?
  • 备查账一般采用什么账簿
  • ubuntu服务
  • cmos是一种什么芯片
  • 桌面上的软件是什么
  • win8.1怎么安装appx没有许可证
  • win10系统中怎么打开IE浏览器
  • win10高对比度设置点了没反应
  • win7如何访问xp
  • win7系统运行速度提升
  • 苹果macmimi
  • win7系统电脑开热点
  • javascript怎么设置
  • js设计模式书
  • pygame如何加载图片
  • 安装下载应用
  • 在javascript中用下面哪个关键词来定义变量
  • js闭包的定义和用途
  • 煤炭洗选工艺
  • 原木进项税率
  • 尾矿治理文件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设