位置: 编程技术 - 正文

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)

  • 境外向国内汇款几天到账
  • 计提的增值税
  • 汇算清缴补交所得税会计分录小企业会计政策
  • 免税合并和应税合并商誉
  • 小规模未达起征点
  • 员工产假个税系统改为非正常要更正申报吗?
  • 不动产经营租赁服务包括哪些
  • 财产租赁合同金额含税吗
  • 用友t3普及版价格
  • 银行网银服务费做什么科目
  • 建筑服务预征缴纳税款本期实际抵减税额怎么填
  • 增值税发票丢了怎么补开
  • 买一送一的营销好处
  • 财产租赁所得适用什么税率
  • 个人独资企业的债务由谁承担
  • 环评费用包括哪些
  • 应纳税额计算举例
  • 如何查询增值税申报表
  • 营改增后附加税费入应交税费还是营业税金及附加
  • 租赁发票交税交多少
  • 健身器材属于哪个部门管理
  • 坏账准备的计提应当关注
  • 材料验收入库的会计科目
  • 清理费用影响当期损益吗
  • 鸿蒙系统桌面文件夹建立
  • 电脑系统还原步骤
  • 0x8000005解决方案
  • 发放福利视同销售进项税要转出吗?
  • 公司车辆违章怎么办
  • 固定资产计提完折旧怎么处理
  • mid文件和midi文件
  • 仓储费计入存货成本吗
  • 固态硬盘什么牌子性价比高
  • 电脑开机后桌面图标变乱
  • 增值税纳税申报首先要稽核比对
  • 应收账款和应付账款的管理
  • 承包安装工程怎么报价
  • 喝薏米红豆水最佳时间
  • 送货上门需要其他费用吗
  • 停车费过路费和汽油费可以一起报销吗
  • 亏损企业所得税怎么交
  • promise的几种状态
  • ChatGPT 能自己跑代码了!
  • 社会团体账务处理流程举例
  • 企业研发费用会计处理英文文献
  • 公司注销时多缴税怎么办
  • 织梦使用手册
  • 社会团体费用报销制度
  • 一次性用品可以做什么东西
  • mysql数据库的设计与实现
  • 坏账准备计提方法一经确定不得随意变更这种做法体现了
  • 科目汇总表借方和贷方相等吗
  • 计提时的会计分录
  • 软件开发是否属于采购目录
  • 如何把凭证装订机弄坏
  • 企业开了发票
  • 电脑操作系统win7
  • macbookpro蓝牙找不到
  • windows提示滑动以关闭电脑
  • macbook系统快捷键
  • 在ubuntu上安装gcc
  • 盗版win7怎么升级
  • unix2dos命令
  • Win10红石版Edge浏览器新扩展功能:关灯(附扩展程序使用)
  • 在linux系统中,用来存放系统所需要的配置文件
  • win8操作系统
  • opengles 旋转 平移 缩放
  • javascript中的3种继承实现方法
  • javascript学习指南
  • 可以自己做手写的软件
  • jquery 属性
  • 基于web的学生成绩管理系统毕业论文
  • vue异步加载第三方库
  • window.open失效
  • node用mongodb还是mysql好
  • shell输出1到100
  • 怎么将安卓
  • 国家税务总局会议管理办法
  • 江苏电子税务局电话
  • 国税局黑龙江省
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设