位置: 编程技术 - 正文

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)

  • 购销合同印花税按70%
  • 应交城建税计入哪个科目
  • 年度部门决算报表系统路径
  • 工业企业取得土地收益
  • 个人所得税申报方式选哪个比较好
  • 报关单汇率按出口日期还是申报日期
  • 退回多报的教育费附加如何做账
  • 定额中税金包含什么
  • 境外设计费涉及税收
  • 哪些车辆可退还车款
  • 支票去银行怎么进账
  • 股息收入所得税率
  • 在建工程购入的空调怎样入账
  • 企业收到个体户开的发票
  • 计件工资的计算
  • 转租的门面怎么办营业执照
  • 补发以前年度工资如何计税
  • 支付跨年租金如何处理
  • 年终奖不走工资走存单,需要缴税吗?
  • 如何查询增值税申报表
  • 劳务费做账要交个人所得税吗?
  • 继承或赠与所得的房产
  • 营改增后小规模纳税人如何报税
  • 承兑汇票如何背书转让
  • 零星工程实施流程
  • 建筑公司收到的劳务费怎么做账
  • 进口增值税属于海关代征的税收吗
  • 赠品如何做兑换码
  • 实例简介php的一般过程
  • 电冰箱一天用多少电费正常
  • php语言之mysql操作
  • win 8和win 7有什么区别
  • 中秋节福利产品清单
  • 股权转让合同怎么解除
  • 坏账损失可以做销项税转出吗
  • 以银行存款交纳欠缴税金会计分录
  • 印花税土地使用税和房产税怎么做会计分录
  • laravel5.4生成验证码的实例讲解
  • 应交增值税转入营业外收入摘要怎么写
  • 蒙特城堡干红葡萄酒价格
  • 学生个人网页制作html5
  • php如何安装配置
  • 什么是现金流量净额
  • 购进原材料款项未付应编制什么凭证
  • 办公费用的核算方法
  • 什么叫做归属
  • 公司赠送客户的产品怎么核算
  • 公司买汽车计入什么费用
  • phpcms建站教程
  • mysql备份方式有哪些
  • 无偿提供建筑服务账务处理
  • 印花税怎么申报2023
  • 大数据sql教程
  • 发明专利权限的期限是多少年
  • 资产减值损失的账务处理
  • 可抵扣的税票
  • mysql join查询慢
  • linux opencl
  • 苹果MAC电脑怎么玩圣安地列斯
  • centos什么命令都说找不到
  • win7登录不进去
  • windows8如何共享打印机
  • win7系统虚拟机
  • freebsd连接wifi
  • nodejs代码规范
  • android studio 新建项目只有.idea文件
  • srslte源码分析
  • 你有一份来信
  • 单机模式在哪
  • javascript例题
  • javascrip语言
  • android:fragment
  • 企业自建旧房产怎么处理
  • 02112366电子税务局
  • 社保当月减员当月还可以增加上吗
  • 北京地方税务局李宗定
  • 航天信息的金税盘开票要怎么调格式
  • 税务有问题会罚多少钱?
  • 地税纳税申报表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设