位置: 编程技术 - 正文

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)

  • 商品房销售税率10%执行时间
  • 下列哪些收入为免税收入
  • 个人所得税中社保填写在哪昆山
  • 注册资本没有全额怎么办
  • 增值税专票已经报税作废不了怎么办
  • 工会经费支付福利方案
  • 公司福利可以抵扣所得税吗
  • 小微企业的企业所得税税收优惠政策
  • 其他收益科目是否征收企业所得税
  • 出纳购买东西能报销吗
  • 增值税专用发票可以开电子发票吗
  • 建筑行业简易计税账务处理
  • 企业所得税债务重组所得
  • 工程款开票后增值税怎么做分录?
  • 销售费用变动率公式
  • 公司购买物品流程
  • 开具的电子发票需要打印出来做账吗
  • 路由器和光猫上的无线网络名称一样吗
  • 企业债券和公司债券
  • 个税手续费返还要交企业所得税吗
  • 会计凭证和记账凭证的区别是什么
  • win11有什么升级
  • 资产负债表存货包括哪些科目
  • 计划成本法购入材料
  • 坏账损失和坏账准备
  • 无形资产处置收入计入
  • 发票开具的有哪些原则
  • 偏食和挑食会有什么不良后果?
  • php操作步骤
  • php时间戳转换中国标准时间
  • 报销凭证写错了怎么办
  • thinkphp cli
  • jsp做登录界面
  • 无数据库cms
  • thinkphp教程
  • 未达起征点的增值税怎么账务处理
  • 电子承兑接收了,但是后来怎么没有了
  • 学电脑网站
  • python ide包括哪些
  • php cms
  • 坏账准备计提比例一般是多少
  • 企业收到海河工厂发运的乙材料,并验收入库
  • 不动产经营租赁发票开具注意
  • 会计分录如何分配利润
  • 收到的发票未抵税怎么办
  • 差旅费所得税扣除标准2023
  • 融资租赁固定资产折旧年限
  • 赠品视同销售价格如何确定?
  • 纳税人将外购的货物用于非应税项目
  • 管理会计期末存货量怎么算
  • 现金日记账是什么帐
  • 内帐外帐的区别与联系
  • WinXP系统能上qq但打不开网页原因分析及解决方法
  • centos安装位置选择
  • linux以root用户登录
  • win8.1 升级
  • lol进入游戏后电脑没声音
  • xp无法进入桌面怎么办
  • exe什么意思?
  • win7系统的分区类型怎么选
  • windows10用法
  • linux使用范围
  • cocos2dx4.0教程
  • cocos2dx游戏有哪些
  • Android游戏开发实训总结
  • js操作dom节点的方法
  • python的pip安装命令
  • node-red 全局变量
  • js alert()
  • 基于python的聊天软件
  • 安卓手机查看sd卡
  • JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
  • jquery鼠标移动触发
  • python的web框架
  • js中如何在div里写入内容
  • 广东电子税务局手机版
  • 福州税务局几点关门
  • 不想订亲
  • 公司地税申报
  • 企业税收有哪些税种
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设