位置: 编程技术 - 正文

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)

  • 餐厅打包盒算不算商品
  • 清算缴纳企业所得税
  • 发票能减多少税
  • 有金额的框架协议要交印花税吗
  • 向境外支付赔偿金需要发票么
  • 计提工资时金额是应发工资还是实发工资
  • 审计调整有关损害的规定
  • 员工继续教育培训费计什么科
  • 财务将利润表已申报还能修改吗
  • 转让企业全部产权属于增值税征税范围。A对B错
  • 产品售后维修产品介绍
  • 供应商价格折扣
  • 支付税收罚款怎么算企业所得税
  • 结转已完工产品会计分录
  • 未及时转固
  • 注销时分公司欠款怎么办
  • 非基本人员单位部分
  • 代收房租费
  • 从银行贷款转借他人法院如何判
  • 公司基本户没开影响报税吗
  • 现金日记账本月合计图
  • 财务报表教育费附加包含地方教育费附加吗
  • 出口转内销申报需要先做出口退税吗
  • 鸿蒙系统怎么看运行程序
  • 对增值税发票开具方面有何要求?
  • 门店出纳的工作内容
  • 国外交工作的基本出发点和落脚点是
  • php中的header函数
  • php文本转数字
  • 艾叶泡脚的功效与作用及禁忌
  • 织梦地图插件
  • nginx静态文件服务器
  • laravel5.4利用163邮箱发送邮件的步骤详解
  • php 截断
  • ros urdf
  • deepwiser怎么用
  • opencv项目开发实战
  • 哪些情形视同从境外取得收入:
  • 账户利息怎么计算
  • 城市维护建设税是什么意思
  • python监控模块
  • sql server的sql语句
  • sql server2000中事务的类型有
  • 在零售环节征收消费税的是哪些
  • 公司帐户可以转法人私人账户吗
  • 债务转为股份的协议
  • 劳务公司到外地需要交的税
  • 新会计准则贷款计提贷款减值准备的比例
  • 融资租赁租金会计科目
  • 病假补贴需要什么手续
  • 工程物资是
  • 事业单位可以购买工作服吗
  • 财务报表中的存货包括哪些内容
  • 如何理解施工企业的周转材料
  • 员工福利费怎么写分录
  • 赡养老人扣除标准个税
  • 如何设置银行存款日记账
  • Windows 10 PC/Mobile Build 14965预览版推送:改进PC端
  • CentOS里/etc/sysconfig/clock内容解读
  • windows 10 build 9888
  • win10商店是什么
  • SpamSubtract.exe - SpamSubtract是什么进程
  • 怎么关闭xp系统弹窗
  • msswchx.exe - msswchx进程是什么文件 有何作用
  • kernel32在哪个文件夹
  • 怎么解圧
  • win7如何设置桌面背景图
  • win7电脑浏览器怎么设置默认浏览器
  • 怎样解决windows照片查看器无法显示此图片
  • js实现用户登录
  • bootstrap怎么用
  • perl编程
  • data命令
  • jquery配合.NET实现点击指定绑定数据并且能够一键下载
  • c# unity 教程
  • python多进程模块
  • 全国国税税务机关是哪里
  • 建筑工程提前投入使用
  • 国地税发展历程
  • 微信如何查询个人名下所有银行卡
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设