node-red:使用node-red-contrib-amqp节点,实现与RabbitMQ服务器(AMQP)的消息传递


node-red-contrib-amqp节点使用

  • 一、简介
    • 1.1 什么是AMQP协议?
    • 1.2 什么是RabbitMQ? -> 开源的AMQP协议实现
    • 1.3 RabbitMQ的WEB管理界面介绍
    • 1.3 如何实现RabbitMQ的数据采集? -> node-red
  • 二、node-red-contrib-amqp节点安装与使用教程
    • 2.1 节点安装
    • 2.2 节点使用
      • 2.2.1 amqp-broker节点
      • 2.2.2 amqp-in节点
      • 2.2.3 amqp-in-manual-ack节点
      • 2.2.4 amqp-out节点

1

回到目录

一、简介

1.1 什么是AMQP协议?

  AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。
  AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。AMQP协议更多用在企业系统内对数据一致性、稳定性和可靠性要求很高的场景,对性能和吞吐量的要求还在其次。
1

详细内容参考链接:RabbitMQ系列四 AMQP协议介绍

回到目录

1.2 什么是RabbitMQ? -> 开源的AMQP协议实现

  RabbitMQ是一个开源的AMQP协议实现,是在AMQP基础上完整的,可复用的企业消息系统。学习参考链接如下:

  • rabbitMQ官网
  • RabbitMQ 详解:环境搭建教程

1.3 RabbitMQ的WEB管理界面介绍

一、总界面
1

  1. connections:无论生产者还是消费者,都需要与RabbirMQ建立连接后才可以完成消息的生产和消费,在这里可以查看连接情况。
  2. channels:通道,建立连接后,会形成通道,以消息的投递获取以来通道。
  3. Excahnges:较平缓及,用来实现消息的路由。
  4. Queues:队列,即消息队列,消息存放在队列中,等待小品非,消费后被移除队列。

二、获取AMQP协议端口
2
三、查看交换机和路由
3

回到目录

1.3 如何实现RabbitMQ的数据采集? -> node-red

   使用node-red的node-red-contrib-amqp节点,连接到RabbitMQ服务器(AMQP),以使用路由键从某个主题获取一些消息,实现客户端与消息中间件数据的传递。

二、node-red-contrib-amqp节点安装与使用教程

2.1 节点安装

1
  node-red安装节点@meowwolf/node-red-contrib-amqp ,基于AMQP协议,实现客户端与消息中间件数据的传递。

回到目录

2.2 节点使用

2.2.1 amqp-broker节点

   amqp-broker节点是指“AMQP消息代理器”,对应一个RabbitMQ实例,是一种中间件,用于接收、存储和转发消息。

这里的端口查看,请转至上节《1.3 RabbitMQ的WEB管理界面介绍》

1

2.2.2 amqp-in节点

1
  该节点能连接到AMQP代理并获取消息,已msg.payload的形式输出,输出格式如下:
1
节点使用说明如下:
1
其中Exchange Info(交换信息)需要根据RabbitMQ中的实际情况进行配置:

  • type:指的是AMQP的消息路由方式,定义了消息如何从一个发送到AMQP消息代理(broker)的交换机(exchange)路由到一个或多个队列。有topic、direct、fanout和headers四种类型。

以下是这四种类型的简要说明:

  1. Topic Exchange
  • 灵活性最强的一种路由方式。它使用通配符来匹配消息的routing key,并支持模糊匹配和精确匹配。
  • 允许发送者指定routing key,并在其中使用通配符(如“*”和“#”)来表示模式。接收者可以通过绑定与这些模式匹配的routing key来接收消息。
  1. Direct Exchange:
  • 最简单的路由方式。它根据消息的routing key进行精确匹配,将消息路由到与该key完全匹配的队列。
  • 发送者和接收者需要就消息的routing key达成一致,以确保消息能够正确路由。
  1. Fanout Exchange
  • 将收到的所有消息广播到与该交换机绑定的所有队列。它不关心消息的routing key,只是简单地将消息分发给所有连接的队列。
  • 适用于需要将消息发送给多个接收者的场景,例如发布-订阅模型。
  1. Headers Exchange
  • 根据消息头的属性进行路由。发送者可以在消息头中设置一组键值对,而接收者可以绑定特定的键值对来接收消息。
  • 提供了比routing key更复杂的匹配逻辑,但性能通常较差,因此在实际应用中较少使用。
  • Exchange Name :交换机名称
  • RoutingName: 指定一个RoutingKey(路由key),将队列与交换机的绑定

使用示例如下:
1
msg.payload输出示例如下:
1
回到目录

2.2.3 amqp-in-manual-ack节点

1
  该节点实现连接到AMQP代理,接收消息,并手动确认收到。与上节amqp-in节点使用及作用相同,不同的地方在于本节点在接收到消息时,要手动确认收到
  此节点默认将 noAck 设置为 false。您必须通过节点输入发送消息来手动确认或拒绝接收。任何未确认的消息将在客户端关闭或重新启动后重新排队。如果您不需要像这样手动确认消息,请使用 amqp-in 节点。有关如何使用此节点的更多信息,请参阅导入库中的示例流。
回到目录

2.2.4 amqp-out节点

1
  连接到AMQP代理并发送消息。
3
回到目录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/237824.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ultra Mobile PayGO购买充值激活

一、前言 Ultra Mobile PayGO免费无限拨打 80 多个国际目的地,还可以向 190 多个国际目的地发送短信。在现在ai智能时代,我自己也需要一张这样的卡,今天用fomepay的虚拟卡激活了这张电话卡,根据需要按套餐购买。 二、点击申请fom…

vue-pure-admin源码解读与使用

vue-pure-admin 全面使用ESMVue3ViteElement-PlusTypeScript编写的一款后台管理系统(兼容移动端),目前斩获11.5k个star。 界面构成 主题Layout的组成 左边sidebar由Vertical组件定义tab标签栏由layoutHeader组件定义中间Body由appMain组件定义 为何点…

matlab 点云最小二乘拟合空间直线(PCA法)

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。爬虫网站自重。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理 见:matlab 点云最小二乘拟合空间直线。 二、代码实现 clc;clear; %% ----

【数字图像处理】实验三 图像增强

图像增强 一、实验内容: 1. 熟悉和掌握利用Matlab工具进行数字图像的读、写、显示等数字图像处理基本步骤。 2. 熟练掌握各种图像增强的基本原理及方法。 3. 能够从深刻理解图像增强,并能够思考拓展到一定的应用领域。…

VM Group

在复杂方案中模块过多可能造成查看或修改方案时存在视觉混乱,不够直观。此时可利用Group模块进行模块整合,同时Group模式也兼容循环的功能,如下图所示。 双击Group模块可进入Group内部,如下图所示。 在Group模块单击 可设置输入、…

两款超好用的视频翻译软件,适合两种不同场景,必有一款适合你

今天给大家推荐2个视频翻译工具​,分别是: TransDuckYouTube中文配音 这两款工具的核心功能非常类似,核心提供一个视频语言翻译的能力。比如:你要看一个英文视频,它可以帮助你将这个英文视频变为中文视频&#xff0c…

软件系统质量保证计划书

本计划描述了信息系统项目质量保证工作相关的一些情况,是软件质量保证过程和方针在项目中的具体实施计划。 计划中阐述了质量保证工作的基本目标;项目的基本情况;质量保证工作所需的资源;质量保证的主要工作;工作量估算…

postman转参的是“” mybatis将“”当0处理问题

Mybatis中 Integer 值为0时,默认为空字符串的解决办法-蒲公英云 传0当成了"" 解决: mybatis当传入数据类型为Int时并且值为0时,会判断为空字符串-腾讯云开发者社区-腾讯云 https://www.cnblogs.com/shenhaha520/articles/16301304.html 传…

试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B)

试图加载格式不正确的程序。 (异常来自 HRESULT:0x8007000B) c#调用动态库是报错 目前平台改为x64

物业服务投诉反馈建议建议二维码

为高效处理物业方面的投诉问题,进一步提升居住品质。凡尔码平台推出“二维码”便民投诉、反馈方式,如有群租扰民、占用堵塞消防通道或私拉乱建等问题,可以立即扫码或进入“凡尔码”小程序进行投诉或反馈。 如电梯出现故障物业服务企业未及时维…

基于Java SSM框架实现咖啡馆管理系统项目【项目源码+论文说明】计算机毕业设计

基于java的SSM框架实现咖啡馆管理系统演示 摘要 2021是网络科技的时代 ,众多的软件被开发出来,给客户带来了很大的选择余地,而且客户越来越追求更个性的需求。在这种时代背景下,客户对咖啡馆管理系统越来越重视,使更好…

深入理解qs库:简化你的工作流程

前言 在 vue 开发中,处理 url 查询字符串是一个常见的任务。qs 库是一个流行的工具,可以帮助我们轻松地处理 url 查询字符串的编码和解码。本文将介绍 qs 库的基本用法,并结合实例演示帮助你更好地理解和应用这个实用的工具。 一、qs 是什么&…

5. 结构型模式 - 外观模式

亦称: Facade 意图 外观模式是一种结构型设计模式, 能为程序库、 框架或其他复杂类提供一个简单的接口 问题 假设你必须在代码中使用某个复杂的库或框架中的众多对象。 正常情况下, 你需要负责所有对象的初始化工作、 管理其依赖关系并按正确…

Java容器学习,一文读懂Java容器使用知识文集。

🏆作者简介,普修罗双战士,一直追求不断学习和成长,在技术的道路上持续探索和实践。 🏆多年互联网行业从业经验,历任核心研发工程师,项目技术负责人。 🎉欢迎 👍点赞✍评论…

SOLIDWORKS Simulation有限元技巧:模拟放置物品时出现的误区

在solidworks simulation中,我们所知simulation能够对零部件和装配体进行有限元分析,而在这种情况下,为了简单分析,同时也为了减少不必要的运算,很多时候我们会选择对整个装配体或是零部件进行简化,如图二&…

免费分享一套Springboot+Vue前后端分离的个人博客系统,挺漂亮的

大家好,我是java1234_小锋老师,看到一个不错的SpringbootVue前后端分离的个人博客系统,分享下哈。 项目视频演示 【免费】SpringbootVue个人博客系统 毕业设计 Java毕业设计_哔哩哔哩_bilibili【免费】SpringbootVue个人博客系统 毕业设计 …

css linear-gradient和radial-gradient的区别

linear-gradient 和 radial-gradient 是 CSS 中用于创建渐变背景的两种主要方法 1.linear-gradient(线性渐变) linear-gradient 创建沿着一条直线方向的渐变效果。它接受一个角度参数或者两个以上的颜色值作为输入。语法如下: /* 使用角度…

Flink 状态管理与容错机制(CheckPoint SavePoint)的关系

一、什么是状态 无状态计算的例子: 例如一个加法算子,第一次输入235那么以后我多次数据23的时候得到的结果都是5。得出的结论就是,相同的输入都会得到相同的结果,与次数无关。 有状态计算的例子: 访问量的统计&#x…

工业5G路由器提升驾考效率,实现智慧驾考物联网

为了提高驾考的考试效率,更好地服务广大学员,车管所驻考场监控中心结合物联网技术采用智慧驾考系统,实现考场监控、考试员远程监考、学员视频实时回传、自动评判等功能,为驾考公平公正安全提供保障。 该系统由智能监控管理平台和…

深入了解Spring MVC工作流程

目录 1. MVC架构简介 2. Spring MVC的工作流程 2.1. 客户端请求的处理 2.2. 视图解析和渲染 2.3. 响应生成与返回 3. Spring MVC的关键组件 3.1. DispatcherServlet 3.2. HandlerMapping 3.3. Controller 3.4. ViewResolver 4. 结论 Spring MVC(Model-Vi…