nodejs搭建mqtt服务器
时间:2022-07-22
本文章向大家介绍nodejs搭建mqtt服务器,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
首先我们先看一张mqtt的架构原理图:
1、nodejs如何搭建mqtt服务器
nodejs搭建mqtt服务器需要使用mosca包,简单搭建示例代码如下:
var mosca = require('mosca');
var ascoltatore = {
//using ascoltatore
//type: 'mongo',
//url: 'mongodb://localhost:27017/mqtt',
//pubsubCollection: 'ascoltatori',
//mongo: {}
};
var settings = {
port: 1883,
backend: ascoltatore
};
var server = new mosca.Server(settings);
server.on('clientConnected', function (client) {
console.log('client connected', client.id);
});
server.on('ready', setup);
function setup() {
console.log('Mosca server is up and running');
}
上面短短几行代码就搭建了一台mqtt服务器,只不过比较简陋,没有存储信息,mosca基于Ascoltatori模块开发,可以支持基于redis、MongoDB、AMQP、ZeroMQ和MQTT代理等方式的消息持久化。
2、搭建mqtt客户端
搭建客户端需要使用mqtt这个包,这里我们建立两个客户端,a和b,a发布消息,b订阅消息,这样的话a发布消息,b监听到就可以做一些操作。
a的代码如下:
var mqtt = require('mqtt')
var client = mqtt.connect('mqtt://127.0.0.1')
setInterval(() => {
client.publish('presence', '21323132')
}, 1000);
代码原理很简单,链接mqtt服务器,定时并且发布消息,消息主题为presence,注意这个消息主题;
b的代码为:
var mqtt = require('mqtt')
var client = mqtt.connect('mqtt://127.0.0.1')
client.on('connect', function () {
client.subscribe('presence')
})
client.on('message', function (topic, message) {
// message is Buffer
console.log(message.toString())
console.log(topic);
// client.end()
})
b客户端链接mqtt服务器,然后订阅presence主题,如果接收到presence主题的信息就会触发message事件。
这样的话,a端和b端就可以实现通讯了,mqtt服务器是一个中间代理。
3、在浏览器中使用mqtt客户端
如何在浏览器端使用mqtt的客户端呢,这需要借助websocket,mqtt.js为我们扩展了应用,我们只需要将mqtt.js引入到我们的前端项目中,就可以在代码中使用mqtt客户端了,其内部原理依靠的是mqtt服务器。
代码如下:
<html>
<head>
<title>test Ws mqtt.js</title>
</head>
<body>
<script src="./browserMqtt.js"></script>
<script>
var client = mqtt.connect(); // you add a ws:// url here
client.subscribe("mqtt/demo");
client.on("message", function(topic, payload) {
alert([topic, payload].join(": "));
client.end();
});
client.publish("mqtt/demo", "hello world!");
</script>
</body>
</html>
现在前端开发人员一般都借助webpack打包工具,所以直接在项目中使用mqtt这个包就可以了。
以上便在nodejs中使用mqtt的方式了,希望对你有所帮助。
引用资料
https://itbilu.com/nodejs/npm/41wDnJoDg.html
- AI进了直播间,这画风666
- CSS布局:水平居中
- docker学习(4) 一些常用操作
- Java多线程之细说线程池
- Windows8异步编程的注意事项
- Spring(一)Spring的第一滴血
- Flume(一)Flume原理解析
- 我所理解的Remoting (2) :远程对象的生命周期管理[下篇]
- struts2(六)之ognl表达式与ActionContext、ValueStack
- Windows8异步编程的注意事项
- CSS魔法堂:深入理解line-height和vertical-align
- Gradle 10分钟上手指南
- gradle项目中profile的实现
- 欧盟推出“数字经济税收制度”优化了税收制度,却影响区块链行业
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- PyQt5 技术篇-设置alignment对齐方式。Qt Designer设置文本对齐方式。居中、左对齐、右对齐、上对齐、下对齐。
- Nginx部署Vue项目以及解决刷新页面404
- Kafka核心API——Stream API
- Kafka核心API——Consumer消费者
- Kafka核心API——Producer生产者
- Linux Lab v0.5 正式发布,功能强大,用法简单
- Kafka核心API——AdminClient API
- PyQt5 技术篇-调用颜色对话框(QColorDialog)获取颜色,调色板的调用。
- Kafka的安装与配置
- PyQt5 技术篇-如何彻底删除控件?布局移除控件方法。
- PyQt5 技术篇-设置滚动条拉动位置,scrollArea滚动条位置设置方法。
- CentOS8更换yum源后出现同步仓库缓存失败的问题
- log4j配置方式
- 基于MHA搭建MySQL Replication集群高可用架构
- PyQt5 技巧篇-解决相对路径无法加载图片问题,styleSheet通过"相对"路径加载图片,python获取当前运行文件的绝对路径。