OurJS


OurJS-我们的JS, 我们的技术-IT文摘; 专注JS相关领域;
我们热爱编程, 我们热爱技术;我们是高大上, 有品味的码农;

欢迎您订阅我们的技术周刊


我们会向您分享我们精心收集整理的,最新的行业资讯,技术动态,外文翻译,热点文章;
我们使用第三方邮件列表向您推送,我们不保存您的任何个人资料,注重您的隐私,您可以随时退订,

欢迎分享您的观点,经验,技巧,心得

让我们一起找寻程序员的快乐,探索技术, 发现IT人生的乐趣;


本网站使用缓存技术每次加载仅需很小流量, 可在手机中流畅浏览;
如果您发现任何BUG,请即时告知我们: ourjs(at)ourjs.com

Node.JS进程间通讯的几种方法:Redis Publish/Subscribe 和 UDP Socket


分享到


分类 JS学习   关键字 Node.JS   发布 ourjs  1534340256648
注意 转载须保留原文链接,译文链接,作者译者等信息。  

借助 Redis


如果您装有redis客户端就可以通过 redis 的 publish/ subscribe方法来实现进程间通讯,注意一旦使用subscribe,则此 redis 只能接收:SUBSCRIBE、PSUBSCRIBE、UNSUBSCRIBE和PUNSUBSCRIBE 等消息订阅指令,您可以专门创建一个redis实例来进行进程间通信。 

接收端:

var redis = require("redis");
var sub = redis.createClient();

sub.on("message", function (channel, message) {
    console.log("sub channel " + channel + ": " + message);
    msg_count += 1;
    if (msg_count === 3) {
        sub.unsubscribe();
        sub.quit();
        pub.quit();
    }
});
sub.subscribe("a nice channel");

发送端:

var redis = require("redis");
var pub = redis.createClient();

pub.publish("a nice channel", "I am sending a message.");


借助 UDP Socket


如果是本机之间通信,则直接使用node.js内置的udp通信模块就可以了,几乎不会发生丢包问题,实现也非常简单:

发送端:

var dgram = require('dgram')
var client = dgram.createSocket('udp4')
client.send('This is message', 889, '127.0.0.1')
接收端:注意绑定端口需要和发送端的保持一致

var dgram = require('dgram');
var messager = dgram.createSocket('udp4');

messager.on('message', function (msg, rinfo) {
  if (rinfo.address != '127.0.0.1') {
    console.log('非本机消息,忽略,防止恶意消息')
    return
  }

  console.log('rinfo', rinfo)
  console.log('messager got: ', msg.toString());
});

messager.bind(889);

输出:

rinfo { address: '127.0.0.1', family: 'IPv4', port: 55402, size: 15 }
messager got:  This is message

社区评论 ( Beta版 )
OnceDoc 您自己的企业内容管理系统——文档、流程、知识库、报表、网盘All In One

访问404页面,寻找丢失儿童
 热门文章 - 分享最多
  1. Git服务器搭建,多用户组权限控制配置,添加新用户密码登陆
  2. 设置select元素中option的默认值
  3. Node.JS用Path将相对路径转为绝对路径
  4. 用JavaScript将input/textarea中的文本复制粘贴到剪切板
  5. JavaScript用Number/parseInt/parseFloat判断字符串是否为数字
  6. Node.JS命令行或批处理中更改Linux用户密码
  7. 上海行业工资排名:产品经理一骑绝尘,前端排名第二?
  8. JavaScript中新建一个带全局变量参数的new Function动态函数
  9. 用JavaScript实现node.js中的path.join方法
  10. 用 OnceAir 搭建个人Git/Svn/照片备份服务器,每年电费7块钱

 相关阅读 - JS学习
  1. 用JavaScript实现node.js中的path.join方法
  2. JavaScript中新建一个带全局变量参数的new Function动态函数
  3. 设置select元素中option的默认值
  4. JavaScript用Number/parseInt/parseFloat判断字符串是否为数字
  5. 用JavaScript将input/textarea中的文本复制粘贴到剪切板
  6. Node.JS用Path将相对路径转为绝对路径
  7. JS动态滑动切换到页面指定位置
  8. 如何通过网页、客户端、手机APP、路由器查找OnceAir NAS网盘的内网访问地址
  9. JavaScript用new Image实现内网服务器端口扫描
  10. 如何收集捕获Node中的未处理的错误异常信息?

 关键字 - Node.JS
  1. [译]Node.js 框架比较: Express vs. Koa vs. Hapi
  2. Express入门教程:一个简单的博客
  3. 是什么让Node.js比Java更快?为什么NodeJS这么快?
  4. 使用Node.JS批量查找替换目录下文本文件中图片地址内容
  5. 判断Node.JS TCP Socket当前连接状态
  6. Node.JS进程间通讯的几种方法:Redis Publish/Subscribe 和 UDP Socket
  7. Node.JS命令行或批处理中更改Linux用户密码
  8. Node.JS用Path将相对路径转为绝对路径
  9. 使用Node.JS监听文件夹变化
  10. Node.JS循环删除非空文件夹及子目录下的所有文件

 欢迎订阅 - 技术周刊

我们热爱编程, 我们热爱技术; 我们是高端, 大气, 上档次, 有品味, 时刻需要和国际接轨的码农; 欢迎您订阅我们的技术周刊; 您只需要在右上角输入您的邮箱即可; 我们注重您的隐私,您可以随时退订.
加入我们吧! 让我们一起找寻码农的快乐,探索技术, 发现IT人生的乐趣;


 关注我们

我们的微信公众号: ourjs-com
打开微信扫一扫即可关注我们:
IT文摘-程序员(码农)技术周刊

ourjs官方微信号