RocketMq 主题(TOPIC)生产级应用
RocketMq是阿里出品(基于MetaQ)的开源中间件,已捐赠给Apache基金会并成为Apache的顶级项目。基于java语言实现,十万级数据吞吐量,ms级处理速度,分布式架构,功能强大,扩展性强。
官方文档
Linux 安装 RocketMq-CSDN博客
Springboot 集成 RocketMq(入门)-CSDN博客
1.定义
主题是 RocketMQ 中消息传输和存储的顶层容器,用于标识同一类业务逻辑的消息。 主题的作用主要如下:
1.1 定义数据的分类隔离
RocketMQ 建议将不同业务类型的数据拆分到不同的主题中管理,通过主题实现存储的隔离性和订阅隔离性。
1.2 定义数据的身份和权限
RocketMQ 的消息本身是匿名无身份的,同一分类的消息使用相同的主题来做身份识别和权限关理。
2.模型关系

主题是 RocketMQ 的顶层存储,所有消息资源的定义都在主题内部完成,但主题是一个逻辑概念,并不是实际的消息容器。
主题内部由多个队列组成,消息的存储和水平扩展能力最终是由队列实现的;并且针对主题的所有约束和属性设置,最终也是通过主题内部的队列来实现。
3.内部属性
3.1 主题名称
定义:主题的名称,用于标识主题,主题名称集群内全局唯一。
3.2 队列列表
定义:队列作为主题的组成单元,是消息存储的实际容器,一个主题内包含一个或多个队列,消息实际存储在主题的各队列内。
写队列:发送消息时根据写队列数量返回路由信息。
读队列:消费时按照读队列的个数返回路由信息。
3.3 消息类型
定义:主题所支持的消息类型。
Normal:普通消息。
FIFO:顺序消息。
Delay:定时/延时消息。
Transaction:事务消息.
约束:RocketMQ 从5.0版本开始,支持强制校验消息类型,即每个主题只允许发送一种消息类型的消息,这样可以更好的运维和管理生产系统,避免混乱。为保证向下兼容4.x版本行为,强制校验功能默认关闭,推荐通过服务端参数 enableTopicMessageTypeCheck 开启校验。
4.主题的类型

普通主题:这里的topic是用户创建主题。
重试主题:这里的topic是消息发送失败时候系统为之创建的主题。
死信主题:这里的topic类似垃圾箱,无法从中生产或者消费消息。
系统主题:这里的topic是Brocker启动后就自动生成的主题。
5.生产中使用建议
5.1 关闭自动创建主题的功能
主题属于顶层资源和容器,拥有独立的权限管理、可观测性指标采集和监控等能力,创建和管理主题会占用一定的系统资源。因此,生产环境需要严格管理主题资源,请勿随意进行增、删、改、查操作。
5.2 手动控制台创建

5.2.1 队列
当读队列数量 >= 写队列数量业务可以正常进行。
当读队列数量 = 写队列数量效果最佳。
如果想调整读写队列的数量,首先减少写队列数量再减少读队列的数量(确保已读完)。
假设创建了4个写队列2个读队列则有两个队列的消息无法被消费,反之则存在两个空闲的读队列。
RocketMq不直接将读写队列设置相同直接目的是为了安全的收缩队列数量,间接的为了安全的扩容。
5.2.2 perm
6:读写状态,当前队列允许读取消息和写入消息。
4:只读状态,当前队列只允许读取消息,不允许写入消息。
2:只写状态,当前队列只允许写入消息,不允许读取消息。
0:不可读写状态,当前队列不允许读取消息和写入消息。
5.3 单一主题只收发一种类型消息
主题的设计原则为通过主题隔离业务,不同业务逻辑的消息建议使用不同的主题。同一业务逻辑消息的类型都相同,因此,对于指定主题,应该只收发同一种类型的消息。
相关文章:
RocketMq 主题(TOPIC)生产级应用
RocketMq是阿里出品(基于MetaQ)的开源中间件,已捐赠给Apache基金会并成为Apache的顶级项目。基于java语言实现,十万级数据吞吐量,ms级处理速度,分布式架构,功能强大,扩展性强。 官方…...
队列实现栈VS栈实现队列
目录 【1】用队列实现栈 思路分析 易错总结 Queue.c&Queue.h手撕队列 声明栈MyStack 创建&初始化栈myStackCreate 压栈myStackPush 出栈&返回栈顶元素myStackPop 返回栈顶元素myStackTop 判断栈空否myStackEmpty 释放空间myStackFree MyStack总代码…...
C/C++: 统计整数
【问题描述】 输入若干个整数,统计出现次数最多的那个整数。如果出现最多的整数有两个以上,打印最早输入的那个整数。 【输入形式】 从标准输入读取输入。第一行只有一个数字N(1≤N≤10000),代表整数的个数。以后的N行…...
docker容器生成镜像并上传个人账户
登录到 Docker Hub 账户: docker login这将提示你输入你的 Docker Hub 账户名和密码。 为容器创建镜像 docker commit <容器名或容器ID> <你的用户名>/<镜像名:标签>例子 docker commit my_container yourusername/my_image:latest推送镜像到…...
hdlbits系列verilog解答(exams/m2014_q4g)-48
文章目录 一、问题描述二、verilog源码三、仿真结果一、问题描述 本次我们将一次创建多个逻辑门,对两个输入a和b通过组合逻辑实现七种不同的输出: out_and: a and bout_or: a or bout_xor: a xor bout_nand: a nand bout_nor: a nor bout_xnor: a xnor bout_anotb: a and-no…...
在vue或者react或angular中,模板表达式中的箭头函数是无效的吗?为什么无效?
出现此问题的背景: 我在Angular项目中对一个标签属性绑定了一个箭头函数,编译报错。 在vue或者react或angular中,模板表达式中的箭头函数是无效的吗? 在 Vue、React 或 Angular 中,模板表达式中的箭头函数是无效的。…...
C++11『lambda表达式 ‖ 线程库 ‖ 包装器』
✨个人主页: 北 海 🎉所属专栏: C修行之路 🎃操作环境: Visual Studio 2022 版本 17.6.5 文章目录 🌇前言🏙️正文1.lambda表达式1.1.仿函数的使用1.2.lambda表达式的语法1.3.lambda表达式的使用…...
MATLAB算法实战应用案例精讲-【数模应用】漫谈机器学习(四)(附实战案例及代码实现)
目录 机器学习学习路线 学习编写抽象类 固定随机数种子 先加载少量数据...
JavaScript 中松散类型的理解
JavaScript 是一种动态类型语言,它的松散类型是其独特的特性之一。本文将深入探讨 JavaScript 中松散类型的概念以及如何在代码中应用。 引言 JavaScript 是一种强大而灵活的语言,它的松散类型使得变量的类型可以在运行时动态改变。这为开发人员带来了…...
java基于springboot公益帮学网站 新闻发布系统的设计与实现vue
以Java为开发平台,综合利用Java Web开发技术、数据库技术等,开发出公益帮学网站。用户使用版块:可以选择注册并登录,可以浏览信息、可以网上互动、发布文章、内容推荐等。后台管理员管理版块:以管理员身份登录网站后台…...
VMware 安装 Centos7 超详细过程
VMware 安装 Centos7 超详细过程 分类 编程技术 1.软硬件准备 软件:推荐使用 VMware,我用的是 VMware 12 镜像:CentOS6 ,如果没有镜像可以在阿里云下载 centos安装包下载_开源镜像站-阿里云 硬件:因为是在宿主机上运行虚拟化软…...
03:2440--UART
目录 一:UART 1:概念 2:工作模式 3:逻辑电平 4:串口结构图 5:时间的计算 二:寄存器 1:简单的UART传输数据 A:GPHCON--配置引脚 B:GPHUP----使能内部上拉编辑 C: UCON0---设置频率115200 D: ULCON0----数据格式8n1 E:发送数据 A:UTRSTAT0 B:UTXHO--发送数据输…...
Vatee万腾的科技冒险:Vatee独特探索力量的数字化征程
在数字化时代的激流中,Vatee万腾以其独特的科技冒险精神,引领着一场前所未有的数字化征程。这不仅仅是一次冒险,更是对未知的深度探索,将科技的力量推向新的高度。 Vatee万腾在科技领域敢于挑战传统,积极探索未知的可能…...
物联网后端个人第十二周总结
学习工作进度 物联网方面 1.模拟设备通过规则引擎将数据通过mqtt进行转发 在物联网平台上实现模拟设备通过规则引擎将数据通过mqtt进行转发已经全部完成了,所使用的物联网平台在这方面有不少的问题和bug,也可能是没有按照开发者的想法对平台进行使用才导…...
Linux C语言 26-可变参数
Linux C语言 26-可变参数 本节关键字:可变参数、va_list、va_arg、va_end 相关C库函数:va_list、va_arg、va_end 什么是可变参数? C语言中的可变参数是指函数能够接受不定数量的参数。在不确定函数参数时,使用“char *format, …...
Gin 学习笔记02-参数获取
Gin 参数获取 1、获取url 参数2、获取动态 url 参数3、获取 form 表单数据 1、获取url 参数 Query()GetQuery()QueryMap()DefaultQuery() package mainimport ("fmt""github.com/gin-gonic/gin""net/http" )func _query(c *gin.Context) {// 1…...
Uniapp Vue3 基础知识点附带实例
包括数据绑定和计算属性、条件渲染和列表渲染、事件处理、表单输入处理、生命周期钩子、自定义指令和过滤器、路由和导航以及状态管理(如Vuex): <template><div><!-- 条件渲染 --><div v-if"showMessage">…...
【迅搜03】全文检索、文档、倒排索引与分词
全文检索、文档、倒排索引与分词 今天还是概念性的内容,但是这些概念却是整个搜索引擎中最重要的概念。可以说,所有的搜索引擎就是实现了类似的概念才能称之为搜索引擎。而且今天的内容其实都是相关联的,所以不要以为标题上有四个名词就感觉好…...
MySql之索引,视图,事务以及存储过程举例详解
一.数据准备 数据准备可参考下面的链接中的数据准备步骤 MySql之内连接,外连接,左连接,右连接以及子查询举例详解-CSDN博客 (如有问题可在评论区留言) 二.存储过程 1.定义 存储过程 PROCEDURE ,也翻译…...
AR眼镜双目光波导/主板硬件方案
AR(增强现实)技术的发展离不开光学元件,而在其中,光波导和Micro OLED被视为AR眼镜光学方案的黄金搭档。光学元件在AR行业中扮演着核心角色,其成本高昂且直接影响用户体验的亮度、清晰度和大小等因素。AR眼镜的硬件成本中,光机部分…...
网络-八股
文章目录介绍一下TCP/IP模型和OSI模型的区别背景是什么为什么从输入 URL 到页面展示到底发生了什么?DNS查询过程CDN是什么,有什么作用?Cookie和Session是什么?有什么区别?单机上,TCP和UDP服务为什么可以占用…...
MindSpore 动态图与静态图深度解析
MindSpore 动态图与静态图深度解析前言在深度学习框架的世界里,动态图(Dynamic Graph)和静态图(Static Graph)是两种核心的执行模式。它们各有优劣,理解它们的区别对于深度学习开发者来说至关重要。本文将深…...
LCD1602液晶显示屏指令实战指南:从基础到应用
1. LCD1602液晶显示屏基础入门 第一次接触LCD1602时,我完全被它简洁的外观和强大的功能吸引了。这块只有巴掌大小的屏幕,却能清晰显示32个字符,特别适合嵌入式系统的信息展示需求。记得当时为了在Arduino项目上显示温湿度数据,我毫…...
Unity TextMesh Pro字体资产管理与性能优化实战
1. TextMesh Pro字体资产的核心原理 第一次接触TextMesh Pro的开发者往往会被它的字体系统搞懵——为什么同样的字体要区分"Unity字体资产"和"TMP字体资产"?这得从它的底层设计说起。简单来说,Unity字体资产(.ttf/.otf文…...
STM32实战:用定时器中断实现三相锁相环控制(附完整代码)
STM32实战:用定时器中断实现三相锁相环控制(附完整代码) 在工业自动化、新能源发电和电机控制领域,三相锁相环技术是实现电网同步、逆变器控制的核心算法。传统DSP方案虽然性能强大,但对于成本敏感的嵌入式应用&#x…...
优质育苗基质核心标准科普:选对基质,育苗事半功倍
种植过程中,同样的种子、同样的管理方式,育苗效果却天差地别,核心原因就在于育苗基质的选择。很多种植户选购基质只看价格,忽略品质,导致育苗失败、得不偿失。本文科普优质育苗基质的核心判断标准,结合真实…...
如何用wangEditor 5和mammoth.js实现Word文档一键转HTML(附完整代码)
基于wangEditor 5与mammoth.js的Word转HTML全链路解决方案 在内容管理系统、在线文档编辑等场景中,将Word文档无缝转换为网页可编辑的HTML格式是常见的开发需求。传统复制粘贴方式存在图片丢失、样式错乱等问题,而通过wangEditor 5富文本编辑器配合mammo…...
Stata实操:用差分GMM和系统GMM搞定面板数据内生性,附完整代码与检验避坑指南
Stata实战:差分GMM与系统GMM在面板数据内生性问题中的高阶应用 金融数据实验室里,李博士盯着屏幕上的Stata结果窗口皱起了眉头——Sargan检验的p值低得刺眼,AR(2)检验也亮起了红灯。他的企业研发投入与绩效关系研究卡在了模型检验环节&#x…...
【VsCode】告别配置焦虑:一文详解MSVC cl.exe编译C++的完整工作流
1. 为什么选择MSVC cl.exe编译C? 很多刚接触C开发的朋友都会遇到一个灵魂拷问:明明装了Visual Studio,为什么还要折腾VsCode?更让人头大的是,明明电脑里就有现成的MSVC编译器,却总是习惯性去下载MinGW。作为…...
如何免费解锁Cursor AI Pro功能:3个核心技巧完整指南
如何免费解锁Cursor AI Pro功能:3个核心技巧完整指南 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your tria…...
