环球关注:RocketMQ延迟消息简明介绍
目录
前言核心属性RMQ_SYS_SCHEDULE_TOPICFIRST_DELAY_TIMEDELAY_FOR_A_WHILEDELAY_FOR_A_PERIODdelayLevelTableoffsetTable核心方法queueId2DelayLeveldelayLevel2QueueIdupdateOffsetcomputeDeliverTimestampstart()shutdown()load()parseDelayLevel前言
场景可以是这样的,双11抢手机,一个新手机4000-5000,到0点的时候,冲着兴奋劲,抢到了。但是摸了摸钱包,又冷静下来了,好像不是很必要换手机。就放在那里没有支付,过了30分钟,自动取消了。这里就是使用延迟消息的场景,当下单之后,向消息队列发送一条延迟30分钟消费的消息。等到30分钟过了,然后消费消息,执行检查任务,要是对应的订单支付了,就什么都不做,要是没支付,就取消订单。
RocketMQ的延迟消息是org.apache.rocketmq.broker.schedule.ScheduleMessageService
类实现的
核心属性
RMQ_SYS_SCHEDULE_TOPIC
在之前的版本中叫SCHEDULE_TOPIC
,是系统内置的Topic,用来保存所有的定时消息。没有执行的定时消息都会被保存在这个topic中。
(资料图片)
FIRST_DELAY_TIME
第一次执行定时任务的延迟时间,默认是1秒。
private static final long FIRST_DELAY_TIME = 1000L;
DELAY_FOR_A_WHILE
第二次以及之后每次定时任务执行的间隔时间,默认100ms。
private static final long DELAY_FOR_A_WHILE = 100L;
DELAY_FOR_A_PERIOD
若是延迟消息投递失败,则在这个时间过后继续投递,默认10秒。
private static final long DELAY_FOR_A_PERIOD = 10000L;
delayLevelTable
这是保存延迟级别和延迟时间映射关系的地方
private final ConcurrentMapdelayLevelTable = new ConcurrentHashMap (32);
offsetTable
保存延迟级别和对应的消费位点
private final ConcurrentMapoffsetTable = new ConcurrentHashMap (32);
核心方法
queueId2DelayLevel
将queueId转换为延迟级别
public static int queueId2DelayLevel(final int queueId) { return queueId + 1; }
delayLevel2QueueId
将延迟级别转换为queueId
public static int delayLevel2QueueId(final int delayLevel) { return delayLevel - 1; }
updateOffset
更新延迟消息topic的消费位点
private void updateOffset(int delayLevel, long offset) { this.offsetTable.put(delayLevel, offset); if (versionChangeCounter.incrementAndGet() % brokerController.getBrokerConfig().getDelayOffsetUpdateVersionStep() == 0) { long stateMachineVersion = brokerController.getMessageStore() != null ? brokerController.getMessageStore().getStateMachineVersion() : 0; dataVersion.nextVersion(stateMachineVersion); } }
computeDeliverTimestamp
根据延迟消息级别和消息的存储时间计算该延迟消息的投递时间
public long computeDeliverTimestamp(final int delayLevel, final long storeTimestamp) { Long time = this.delayLevelTable.get(delayLevel); if (time != null) { return time + storeTimestamp; } return storeTimestamp + 1000; }
start()
启动延迟消息服务
shutdown()
关闭start方法中启动的额timer任务
load()
加载消息的消费位点信息和全部的延迟级别信息。延迟级别信息默认如下。
private String messageDelayLevel = "1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h";
parseDelayLevel
格式化所有的延迟级别信息,保存到内存中。
到此这篇关于RocketMQ延迟消息简明介绍的文章就介绍到这了,更多相关RocketMQ延迟消息内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 1联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 2亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 3现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 4如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 5AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 6转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 7充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 8好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 9名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 10亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战