位置: 编程技术 - 正文

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)

  • 个人所得税是什么费用
  • 小企业会计准则2023电子版
  • 先报个税还是先报增值税,有影响吗?
  • 金蝶k3生产领料单怎么导入
  • 土地增值税税收优惠
  • 一般纳税人初次购入税控系统的分录怎么做
  • 债务清偿抵充的案例
  • 个体工商户不经营会自动注销吗
  • 承包方给发包方付费
  • 企业取得代扣代缴个税手续费分录
  • 库存现金盘盈的账务处理中可能涉及的科目有
  • 现金福利支出需要申报个税吗
  • 公司章程出资时间怎么填写
  • 资产负债表在建工程怎么填列
  • 减免税款未抵扣增值税
  • 工程用的叉车计提折旧记到什么科目?
  • 进项税额转出能进成本吗
  • 电脑运行慢怎么清理c盘
  • 全额拨款事业单位工资待遇
  • linux系统中查看进程的命令
  • macOS Big Sur 11.2.1 修订版更新发布
  • 破产企业发放工资怎么算
  • 红字发票什么作用
  • reactjs路由跳转
  • thinkphp案例
  • java项目中redis使用实例
  • 数据库系统课程学什么
  • 常用的css样式有哪些
  • python如何导入excel
  • 合伙企业能享受所得税减半征收
  • 普通发票作废要做账吗
  • 预计负债初始计量的最佳估计数的确定是会计估计变更吗
  • 发票6个点怎么算收税点
  • mongodb的坑
  • python方差齐性检验
  • 取得投资是什么意思
  • 无形资产有在建工程吗
  • mysql从一个库导入进另一个库
  • 管理费用如何填列
  • 银行电子承兑到期了怎么兑现操作
  • 进项税转出如何结转
  • 电子发票和增值税发票有什么区别
  • 委托代销业务的会计分录
  • 软件开发销售属于什么行业
  • 怎么调整应收账款分录
  • 现金日记账是会计人员根据审核后的
  • 银行收的账户管理费
  • 农民工专户里的钱能转出来吗
  • 质量问题扣货款会计怎么处理
  • 暂估出口收入如何计算
  • 公司现金支票取现要缴税吗
  • 哪些发票可以报账
  • mysql explain的用法(使用explain优化查询语句)
  • 设置自动清理缓存电脑
  • 清理macbook清除系统垃圾
  • linux的free
  • centos state down
  • 如何去掉windows7开机密码
  • window7激活系统
  • linux主要充当什么样的服务角色
  • win7系统网页无法调用摄像头
  • linux可视化界面怎么输入代码
  • windows如何编辑内容
  • perl如何使用
  • javascript之Array 数组对象详解
  • 跨域请求的三种方法
  • cocos2d教程
  • 显示打包成功但是没有文件
  • Unity3D游戏开发(第2版)pdf
  • .es6文件
  • 非递归快速排序python
  • js快速生成数组
  • unity3d碰撞检测源码
  • 安卓短信提示
  • jq写css样式
  • android完整开源项目
  • python中用户登录
  • 如何查询企业税务情况
  • 互城通怎么用微信充值
  • 无锡电子税务局怎么修改办税人员信息
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设