《云原生》一文搞懂RocketMQ队列概述

news2024/11/17 3:25:37

目录

概念简述

一、客户端概念

1. Topic-主题

2.ConsumerGroup(消费者组)

概念一览图

二、消息传输模型

三、实践应用

1.配置文件

2.生产者

3.消费者

配置一览图

最后的话 


接上一篇对rabbitMQ队列进行了梳理 《一文搞懂rabbitMQ消息队列概述》。

本篇对另一种消息队列rocketMQ进行概述理解。

注:本文依据当前最新版本5.x为基础展开

概念简述

分为三个方面进行分析理解:

  • 客户端概念
  • 消息传输模型
  • 实践应用

一、客户端概念

1. Topic-主题

主题是RocketMQ消息传输和存储的顶层容器,标识同一类业务消息逻辑数据。只是一个逻辑容器,并不是实际的消息容器。

messageType(消息类型)控制台创建主题时,需要设置一种消息类型,后续向该主题传输消息,该主题只会接收对应的消息类型,不匹配的则会直接拒绝接收。

  • Normal(普通消息):没有特殊语义,消息自己没有任何关联
  • FIFO(顺序消息):MQ通过消息分组messageGroup标记一组特定消息的先后顺序,可以保证消息的投递顺序可以严格按照消息的发送顺序进行投递。
  • Delay(定时/延时消息):通过设置延时时间控制消息生产后不立即投递,而是等延时间隔时间后对消费者可见。
  • Transaction(事务消息):rocketMQ支持分布式事务,支持应用数据库消息和消息回调事务一致性保障。

queue(队列):控制台创建主题时,需要设置主题的队列数量,不用单独创建队列,MQ服务器会自动创建。抛开不同服务商的实现,对于队列本身来说,单个queue 具有自然顺序性;

注1:对于RocketMQ的队列,还具备一个独一无二的的特性流式操作语义:队列的存储模型可确保消息从任意位点(offset)读取任意数量的消息,以此实现类似聚合读取、回溯读取等特性​​​​​​。

2.ConsumerGroup(消费者组)

概念:是Apache RocketMQ中存在多个消费行为一直的消费者负载均衡分组。

投递顺序性:控制台创建消费者分组时,需要设置一种消费者投递的顺序。

  • 顺序投递:消费顺序和发送顺序完全一致。
  • 并发投递:并发消费,尽可能按时间顺序处理。

    注2:按消费者是否设置消费者组,对于投递顺序性有不同的特性,详细可参考RocketMQ官网消费者组详解

消费重试策略:控制台创建消费者分组时设置。保证消费者消费消息异常或失败后出去的重试策略。

  • 重试次数
  • 死信队列设置
  • 重试时间间隔
  • ...

        注3:根据消费者类型不同,重试触发时机存在差异

                (1)PushConsumer:异常时返回失败状态码,立即重试     

                 (2)SimpleConsumer:静默等待超时,服务器自动重试

        注4:建议通过减少重试次数+延长重试间隔来降低系统压力,避免出现无限重试或大量重试的情况。

在控制台中 topic主题 与 consumerGroup消费者组 没有直接的关联

概念一览图

二、消息传输模型

MQ的消息传输模型大致分为两类:点对点消息模型、发布/订阅消息模型

Apache RocketMQ只支持一种消息模型:发布/订阅消息模型

注5:Apache RabbitMQ两种消息传输模型都支持

三、实践应用

1.配置文件

  • nameServer:服务器地址(控制台获取)
  • AccessKey(控制台获取)
  • SecretKey(控制台)
  • producer groupId(客户端自定义设置)

2.生产者

  • topic:主题(控制台获取)
  • messageKey:消息唯一索引键(客户端自定义设置)
  • messageBody:消息内容体(客户端自定义设置)
  • messageTag:消息过滤标签(客户端自定义设置)

3.消费者

  • topic:主题(控制台获取)
  • consumerGroup:消费者组(控制台获取)
  • messageTag:消息过滤标签(客户端自定义设置,与生产者过滤标签对应

消费者订阅关系

        上面说到控制台topic与consumerGroup没有直接的关联,其实是在客户端通过消费者产生的联系。

项目中集成RocketMQ可参考: springboot 整合 腾讯云RocketMq版消息队列服务

配置一览图


最后的话 

至此rocketMQ的基本概念大致清楚了,但是想要生产运用不仅仅止步于表面,自己更需要去深耕框架底层的逻辑实现,才能真正掌握并达到事半功倍的效果。

行动起来

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

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

相关文章

shell技术

退出状态码 Shell 中运行的命令会使用0-255之间的整数值,作为退出状态码,并以此来告知shell该命令执行的状态。 通常情况下,约定0代表命令成功结束,非0代表程序非正常退出。 假如没有指定返回值,那么会用脚本的最后一个命令的执…

华为路由器配置笔记

路由器(Router),是连接因特网中各局域网、广域网的设备,它会根据信道的情况自动选择和设定路由,以最佳路径,按前后顺序发送信号,路由器工作在网络层,用来跨网段通信,路由器具有判断网络地址和选择IP路径的功能,它能在多网络互联环境中,建立灵活的连接,可用完全不同的数据分组和…

巧用数据分析表达式,让数据指标创建更简单

实现数据业务一体化的指标分析 从零售系统进化史get 数据统计的需求变更 零售系统需要的数据统计需求 V1.0 只需要获取当日累计的销售额,于是店老板就用 Excel或者纸质的表格创建了一个表,表中包含销售的日期时间,销售的产品,销…

c语言的变量和指针,怎么理解?

学会应用指针是C语言程序员的分水岭,也是C程序员级别的试金石。 变量可以分为基础变量、数组变量、指针变量,其中数组变量非常特殊,可以进一步分为基础数组变量和指针数组变量,所以暂时不考虑数组变量。假设我们在32位计算机上工…

【云原生】k8s之pod基础(下)

内容预知 1.pod的镜像拉取策略 1.1 镜像拉取说明 1.2 镜像拉取的策略 1.3 镜像拉取策略的设置操作 (1)Never策略的使用 (2)IfNotPresent策略在本地无镜像的情况下使用 (3) IfNotPresent策略在本地有…

客观认识植物乳杆菌 (L. plantarum) 及其健康益处

人体消化系统包含大约几百到几千种不同的细菌种类,其丰度构成因人而异。 其中少数益生菌乳杆菌属,即嗜酸乳杆菌、植物乳杆菌、短乳杆菌、乳酸乳杆菌、干酪乳杆菌、保加利亚乳杆菌、发酵乳杆菌、鼠李糖乳杆菌特异性产生细胞外蛋白、胞外多糖、细菌素和脂磷…

信息安全治理-信息安全状态示例

声明 本文是学习github5.com 网站的报告而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 信息安全治理-信息安全状态示例 组织可以生成一个信息安全状态,并将其作为信息安全的沟通工具披露给利益相关者。 组织宜选择和决定信息安全状态的格…

Curve 分布式存储在 KubeSphere 中的实践

Curve 介绍 Curve 是网易开发的现代存储系统,目前支持文件存储 (CurveFS) 和块存储 (CurveBS)。现在它作为一个沙盒项目托管在 CNCF。 Curve 是一个高性能、轻量级操作、本地云的开源分布式存储系统。Curve 可以应用于 : 1) 主流云本地基础设施平台 OpenStack 和…

【Bigdata】【Java】用IDEA创建一个Maven项目时,一直卡在Generating project in Batch mode步骤

Project Scenario(项目场景): I want to create a Maven project with IDEA to practice writing UDF functions and upload it to hdfs, so I need to initialize the maven project. (本人想用IDEA创建一个Maven项目来练习UDF函…

Netty初探

序: 为什么打算写Netty 相关的博客呢? Netty如今已经是应用非常广泛了, 很多框架底层都能看到他的影子,如Dubbo , Spring Gateway , RocketMQ、Elasticsearch、HBase 等比较出名的框架,在性能,…

使用div+css实现表格布局

DIVCSS是WEB设计标准,它是一种网页的布局方法。与传统中通过表格(table)布局定位的方式不同,它可以实现网页页面内容与表现相分离。提起DIVCSS组合,还要从XHTML说起。XHTML是一种在HTML(标准通用标记语言的…

【MySQL】【systemd】mysqld_pre_systemd 及 mysqld@.service 的 bugs

mysqld_pre_systemd 及 mysqld.service 的 bugs问题原理mysqld_pre_systemd 的 bugsmysqld.service 的 bugs测试案例重现不指定 datadir 和 log-error 的 bugs开启 SELinux ,指定不同于默认值的自定义数据目录和错误日志位置进行测试修正方法方法一:向 m…

【Word】MathType 运行时错误‘53’:文件未找到:MathPage.WLL

问题描述 1. 环境: MathType7.4Microsoft Office 365Windows 11 2. 问题 情景1. Microsoft Word 启动时显示 Please reload Word to load MathType addin properly 情景2. 安装MathType后在 Microsoft Word 中使用复制粘贴时报错 运行时错误‘53’ 情景3. 在 M…

JavaScript 对象-三种创建对象的方式,遍历获取到对象。

JavaScript 对象-三种创建对象的方式,遍历获取到对象。 目录JavaScript 对象-三种创建对象的方式,遍历获取到对象。1. 对象1.1 什么是对象?1.2 为什么需要对象2. 创建对象的三种方式2.1 利用字面量创建对象2.2 利用new Object创建对象2.3 利用…

【数组】leetcode209.有序数组的平方(C/C++/Java/Js)

leetcode209.长度最小的子数组1 题目2 思路-滑动窗口3 代码3.1 C版本3.2 C版本3.3 Java版本3.4 JavaScript版本4 总结1 题目 题源链接 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl1, …, nu…

系列教程之《高铁上的GO》-第一篇

作者:坚果,OpenHarmony布道师,OpenHarmony校源行开源大使,CSDN博客专家,电子发烧友鸿蒙MVP,51CTO博客专家博主,阿里云博客专家。 本文主要讲解Go是什么,Go如何安装,开发G…

【Docker】(二)使用Dockerfile构建并发布一个SpringBoot服务

1.前言 在上一篇笔记 Docker基本概念与安装 中,我们已经获取到了一个Docker服务,并了解了Docker的基本组成及其各个组件的作用。 我们了解到,使用Docker的其中一个目的,是为了更加简单,方便的部署我们编写的服务&…

Typora下载和Markdown基础语法

本章内容如下: Typoar笔记下载资源及主题设置Markdown语法使用的基本方法 这篇博客一开始是为了教女朋友如何使用Typora和Markdown语法写的笔记,Markdown语法的内容不太全,只涉及基础使用。 文章目录Typora下载与主题设置Typora主题设置修改图…

在线考试答题系统的五大功能,你知道多少?

在线考试答题系统-五大功能,你知道多少?-在线考试答题系统优势:在线考试答题系统具有高度的可扩展性,高效灵活、功能强大。考试用户随时随地就可通过网络登录在线考试答题系统,参加在线报名、在线练习、在线考试、在线…

嵌入式开发中为什么选择C语言?它有哪些特点?

众所周知,C语言在嵌入式开发中占据着十分重要的地位,为什么嵌入式开发要选择C语言?嵌入式开发的方向可以分为单片机开发、Linx应用开发和现场可编辑逻辑门阵列(FPGA)开发,不同于传统开发模式,操作系统是嵌入…