使用 nodejs 快速搭建 MQTT 服务器及实时推送、获取数据

本文首发于个人网站,永久地址:https://iiter.cn/blogs/13 点进去给几个访问量也行啊
github 仓库源代码:github

MQTT 的概念

MQTT(Message Queue Telemetry Transport,翻译成中文为消息队列遥测传输)是 ISO 标准(ISO/IEC PRF 20922)下基于发布/订阅范式的消息协议。它工作在 TCP/IP 协议族上,是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议,为此,它需要一个消息中间件 。

MQTT 是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT 协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(IoT)。其在,通过卫星链路通信传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已广泛使用。

看到这,我们可能或许大概已经明白,MQTT 这货就是个通信协议,且被广泛应用在 M2M、IoT、智能家居等环境中。下面这张图,可以让我们更清楚的了解它具体的应用场景

和其他传输协议的区别

看到这里就有人想不明白了,MQTT 既然也是一个基于客户端-服务器的消息发布/订阅传输协议,那么它和我们平常所使用的 websocket 有什么区别呢?
借用百度物联网产品经理的知乎回答:

两者的应用场景不一样:

  • MQTT 是为了物联网场景设计的基于 TCP 的 Pub/Sub 协议,有许多为物联网优化的特性,比如适应不同网络的 QoS、层级主题、遗言等等。
  • WebSocket 是为了 HTML5 应用方便与服务器双向通讯而设计的协议,HTTP 握手然后转 TCP 协议,用于取代之前的 Server Push、Comet、长轮询等老旧实现。两者之所有有交集,是因为一个应用场景:如何通过 HTML5 应用来作为 MQTT 的客户端,以便接受设备消息或者向设备发送信息,那么 MQTT over WebSocket 自然成了最合理的途径了。

MQTT 客户端的语言支持

  • Java
  • Javascript
  • C/C++
  • Python
  • Ruby
  • Objective-C

搭建基于 nodejs 的 MQTT 服务器

创建服务端

1.先从初始化一个 package.json 开始。

npm init

2.安装 mqtt 服务器必要依赖项 mosca mqtt

npm install mosca mqtt

3.根目录下创建 mqtt.js 文件,写入以下内容,创建 mqtt 简易服务器。

const mosca = require("mosca");
const MqttServer = new mosca.Server({
  port: 1883
});
MqttServer.on("clientConnected", function(client) {
  //当有客户端连接时的回调.
  console.log("client connected", client.id);
});
/**
 * 监听MQTT主题消息
 * 当客户端有连接发布主题消息时
 **/
MqttServer.on("published", function(packet, client) {
  var topic = packet.topic;
  switch (topic) {
    case "temperature":
      // console.log('message-publish', packet.payload.toString());
      //MQTT可以转发主题消息至其他主题
      //MqttServer.publish({ topic: 'other', payload: 'sssss' });
      break;
    case "other":
      console.log("message-123", packet.payload.toString());
      break;
  }
});

MqttServer.on("ready", function() {
  //当服务开启时的回调
  console.log("mqtt is running...");
});
创建客户端推送

根目录下创建 publish.js 推送文件,写入以下内容:

const mqtt = require("mqtt");
const client = mqtt.connect("mqtt://127.0.0.1:1883"); //连接到mqtt服务端
//写个定时器定时每隔3秒定时推送天气信息,此业务可替换为自己的实际需求
setInterval(function() {
  const value = Math.ceil(Math.random() * 40);
  client.publish("temperature", value.toString(), { qos: 0, retain: true });
}, 3000);
创建客户端接收

根目录下创建 subscribe.js 接收文件,写入以下内容:

const mqtt = require("mqtt");
// const mqtt = require('./node_modules/mqtt/dist/mqtt.min.js')
const client = mqtt.connect("mqtt://127.0.0.1:1883"); //指定服务端地址和端口

client.on("connect", function() {
  console.log("服务器连接成功");
  // connected = client.connected
  client.subscribe("temperature", { qos: 1 }); //订阅主题为test的消息
});
client.on("message", function(top, message) {
  console.log("当前topic:", top);
  console.log("当前温度:", message.toString());
});
测试功能

1.启动服务端 mqtt.js
根目录下命令行输入 node mqtt.js/node mqtt 运行服务端,启动成功出现以下信息:

2.启动推送客户端 publish.js
根目录下命令行输入 node publish.js/node publish 运行推送客户端 3.启动接收客户端 subscribe.js
根目录下命令行输入 node subscribe.js/node subscribe 运行接收客户端,不出意外,控制台将会每隔 5 秒打印以下信息:

至此,一个基于 nodejs 的简易 mqtt 服务器就搭建完成了。

  • 12
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值