消息中间件(RocketMQ)笔记

本文涉及的产品
云原生网关 MSE Higress,422元/月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 分布式消息中间件,主要是实现分布式系统中解耦、异步消息、流量销锋、日志处理等场景。生产中用的最多的消息队列有Activemq,rabbitmq,kafka,rocketmq等。以 Jms 规范和 rocketmq 为主来分享。版本基于 3.2.6 。主要分享:JMS规范、Rocketmq的介绍、部署方式、特性的一些使用。

1、rocketmq是分布式消息中间件,消息队列。支持同步、异步、单向。
 (1)同步:发送请求后,会同步等待Broker服务器返回结果,支持发送失败重试,适用于比较重要的消息通知场景。
 (2)异步:异步发送请求,不会阻塞当前线程,不支持失败重试,适用于对响应时间要求更高的场景。
 (3)单向:单向发送原理和异步一致,但不支持回调。适用于响应时间非常短,对可靠性要求不高的场景,例如日志收集。
2、四大核心模块组成:producer、consumer、brokerServer、nameServer。前两个是客户端,后两个是服务端。
3、由于rocketmq采用ack机制保证消息的消费成功,因此consumer可能会多次收到同一条消息,需要做好幂等防护。
4、brokerServer多采用集群部署,因此需要nameServer保存brokerServer的路由信息。broker每次上下线都会和nameServer通信。producer和consumer通过nameServer获取对应的broker路由信息,再向对应的broker发起请求。
5、核心模块关系图:
QQ截图20221025132836.png
6、基本概念
 (1)topic主题:任何消息都只属于一个topic。
 (2)tag标签:从属于topic主题,对同一主题下的消息进行进一步区分。
 (3)group组:代表同一类的客户端的集合。具体可分为消费者组和生产者组。同一组通常处理同样的消息,处理逻辑也一致。
 (4)message消息:具有全局唯一的messageID属性。
 (5)集群消费、广播消费、混合模式消费:集群消费是同一消费者组的每个节点分摊消息,即每个节点处理的消息是不同的;广播消费是同一消费者组的每个节点都会消费,即每个节点处理的消息是一样的;混合模式消费是多个消费组,每个消费组全量消费,组内再分摊。
7、安装后的测试启动顺序:nameServer》brokerServer》consumer》producer。

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
1月前
|
消息中间件 存储 RocketMQ
消息中间件-RocketMQ技术(二)
消息中间件-RocketMQ技术(二)
|
1月前
|
消息中间件 存储 中间件
消息中间件-RocketMQ技术(一)
消息中间件-RocketMQ技术(一)
|
3月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
263 3
|
9天前
|
消息中间件 编解码 Docker
【Docker项目实战】Docker部署RabbitMQ消息中间件
【10月更文挑战第8天】Docker部署RabbitMQ消息中间件
22 0
【Docker项目实战】Docker部署RabbitMQ消息中间件
|
2月前
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
2月前
|
消息中间件 Docker 容器
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
这篇文章提供了RabbitMQ的安装和基本使用教程,包括如何使用Docker拉取RabbitMQ镜像、创建容器、通过浏览器访问管理界面,以及如何创建交换机、队列、绑定和使用direct、fanout和topic三种类型的交换器进行消息发布和接收的测试。
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
|
2月前
|
消息中间件 存储 网络协议
消息中间件RabbitMQ---概述和概念 【一】
该文章提供了对消息中间件RabbitMQ的全面概述,包括其核心概念、工作原理以及与AMQP和JMS的关系。
消息中间件RabbitMQ---概述和概念 【一】
|
3月前
|
消息中间件 缓存 IDE
MetaQ/RocketMQ 原理问题之消息队列中间件的问题如何解决
MetaQ/RocketMQ 原理问题之消息队列中间件的问题如何解决
|
3月前
|
消息中间件 监控 负载均衡
中间件RabbitMQ性能瓶颈
【7月更文挑战第13天】
217 11
|
4天前
|
消息中间件 存储 弹性计算
云消息队列RabbitMQ实践
云消息队列RabbitMQ实践

相关产品

  • 云消息队列 MQ