你们团队是否有RocketMQ创建Topic、GID创建规范呢

这里是weihubeats ,觉得文章不错可以关注公众号小奏技术

背景

早期在使用RocketMQ的时候,系统和开发人员不算多。所以topic的创建会非常随意,各种千奇百怪的topic

比如: order_topicORDER_TOPICorder-topic

各种奇奇怪怪的风格,用_的,用驼峰的,纯大写加下划线的。各种风格

其实这个还不是主要的,比如上面的order_topic,你大致知道这个topic是属于订单组的,比如如果我们出现了一个domain_eventtopic,这时候我们去看这个topic,他是属于哪个系统的呢?实际会比较困惑

包括比如要消费这个topic,我们可以有如下gid gid_domian_event

我看了这个gid也不知道这个gid属于哪个系统的,是属于自己系统消费自己的topic,还是属于其他系统消费domian_event这个topic

所以可以看到如果没有一个topicgid创建规范,有时候这些topicgid会非常没有意义,在做topic或者gid维护的时候看这些名字是非常没有意义的

Topic规范

topic的创建规范我们推荐是 serviceName + topicName(业务名称)

举个🌰

比如我们有订单系统(order)要创建自己的领域事件topic

topic名称为:order-domain-event-topic

消费者(gid)规范

规范:gid + 消费系统 + consume + topic

如果是自己消费自己则省略 消费系统 + consume变成

gid + topic

举个🌰

比如我们支付要消费订单的topic 那么我们的gid为

gid-pay-consume-order-domain-event-topic

如果订单要消费自己的topic呢?

那我们就可以省略 消费系统 + consume,直接是gid+topic

比如 gid-order-domain-event-topic

一些错误的gid命名例子

收益

这样我们看到每个topicgid就知道是干嘛的了

比如给你一个order-domain-event-topic

你就知道是订单组的领域事件topic

看到gid-order-domain-event-topic 就是订单组自己消费自己的order-domain-event-topic

看到gid-pay-consume-order-domain-event-topic就知道是支付用来消费订单的order-domain-event-topic topic

当然如果公司有足够的研发资源还是可以自研RocketMQ 的dashboard,从流程上去规范topic的创建,比如创建topic的时候需要说明属于哪个系统,用途等

不知道其他小伙伴有没有什么更好的建议呢

相关推荐
GoppViper5 分钟前
uniapp中实现<text>文本内容点击可复制或拨打电话
前端·后端·前端框架·uni-app·前端开发
不染_是非10 分钟前
Django学习实战篇四(适合略有基础的新手小白学习)(从0开发项目)
数据库·后端·学习·django·web
bluebonnet271 小时前
【Rust练习】15.match 和 if let
开发语言·后端·rust
ZachOn1y2 小时前
Java 入门指南:JVM(Java虚拟机)垃圾回收机制 —— 死亡对象判断方法
java·jvm·后端·java-ee·团队开发·个人开发
ZachOn1y2 小时前
Java 入门指南:JVM(Java虚拟机)垃圾回收机制 —— 内存分配和回收规则
java·jvm·后端·个人开发
易云码2 小时前
【工作流集成】springboot+vue工作流审批系统(实际源码)
大数据·后端·低代码·系统安全·设计规范
jingling5553 小时前
后端开发刷题 | 最长上升子序列
java·开发语言·数据结构·后端·算法·动态规划
Flying_Fish_roe3 小时前
Spring Boot- 数据库相关问题
java·spring boot·后端
我叫啥都行4 小时前
计算机基础知识复习9.13
linux·笔记·后端·系统架构
从零开始的-CodeNinja之路4 小时前
【Spring Boot】SpringBoot自动装配-Import
java·spring boot·后端