位置: 编程技术 - 正文

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)

  • 进料加工贸易流程
  • 解除劳动一次性补偿金怎么记账
  • 公司垫付生育津贴凭证
  • 多交的增值税和附加税退回,如何记账
  • 怎么增加资产减少负债
  • 办公室水电费计算公式
  • 企业所得税成本调减怎么填
  • 单位购买定制的器材
  • 超范围经营可以赔偿吗
  • 购入资产的入账价格一般是以该项资产的什么反应
  • 包工包料和包清工
  • 小微企业的认定标准2021
  • 办公楼贷款比例
  • 生产部门的费用计入什么科目
  • 建筑安装企业成本费用包括哪些
  • 车船税法律制度的规定什么是以每米为计税依据的
  • 实收资本重复交的印花税可以申请退税吗?
  • 汇算清缴时资产总额如何计算
  • 增值税进项和销项税的计算方法
  • 工程款税款税率
  • 资产减值损失属于什么科目借方增加还是减少
  • 外贸企业出口退税流程图
  • 员工垫付差旅费 民间借贷
  • 转销和冲销是什么意思
  • 已预缴税款金额可以不申请退税吗
  • 取得高新技术企业
  • 企业土地未全部使用如何缴纳房产税?
  • 家常煲汤500例的做法窍门
  • 电脑怎么安装安卓软件
  • win7系统的系统配置里设置开机启动项
  • 进口货物可以退回吗
  • 华为应用市场被锁了,怎么解除密码
  • PHP:xml_get_current_column_number()的用法_XML解析器函数
  • php unit
  • linux 数据类型
  • 进程查看工具
  • 跳出框架是什么意思
  • 固定资产的特征有哪些
  • 劳务公司怎么开税票
  • PostgreSQL教程(三):表的继承和分区表详解
  • 公司代扣代缴个人所得税是怎么算的
  • 个体工商户纳税申抿
  • 专票没有抵扣联可以作废吗
  • 快速实现愿望超灵的方法
  • 公允价值变动是一级科目吗
  • 结算备付金会计分录
  • 先收票后收货
  • 应交税费进项税额转出期末怎么结转
  • 计提社保和工资一起怎么做账
  • 计提税金及附加会计分录怎么做
  • 城镇土地使用税的计税依据
  • 进项发票可以退税吗
  • 汇算清缴后多交的企业所得税能退吗
  • 税款滞纳金征收比率怎么算
  • 免征的附加税怎么做账
  • 有销项税额转出吗
  • 补缴以前年度企业所得税分录怎么写
  • 为什么需要会计信息
  • 年度利润总额怎么填
  • 工业企业待摊费用标准
  • sql server的修改语句
  • Vista 优化预读文件设置,提速开关机速度
  • centos7 nis
  • 苹果电脑旋转屏幕设置在哪里找
  • win10预览版好吗
  • win10周年版
  • js 高级技巧
  • android获取json数据
  • Node.js中的construct
  • jquery的点击事件怎么写
  • Node.js中的什么模块是用于处理文件和目录的
  • kill某个进程
  • html5 jquery
  • JavaScript、tab切换完整版(自动切换、鼠标移入停止、移开运行)
  • python中email模块
  • jQuery Ajax 全局调用封装实例代码详解
  • 社保归国税还是地税
  • 从香港回内地需要做核酸检测吗
  • 南宁地方税务局网站
  • 货车可申请停保吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设