From 8d92df4587c9934705797a9bcb0036f88b36218d Mon Sep 17 00:00:00 2001 From: dingshuangxi888 Date: Tue, 21 Jan 2025 13:37:16 +0800 Subject: [PATCH] Assign offset in offsetTable even if the subscription key not exist. --- .../apache/rocketmq/broker/offset/ConsumerOffsetManager.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/broker/src/main/java/org/apache/rocketmq/broker/offset/ConsumerOffsetManager.java b/broker/src/main/java/org/apache/rocketmq/broker/offset/ConsumerOffsetManager.java index 34f23b754bc..85bc8e37896 100644 --- a/broker/src/main/java/org/apache/rocketmq/broker/offset/ConsumerOffsetManager.java +++ b/broker/src/main/java/org/apache/rocketmq/broker/offset/ConsumerOffsetManager.java @@ -418,14 +418,14 @@ public void assignResetOffset(String topic, String group, int queueId, long offs } String key = topic + TOPIC_GROUP_SEPARATOR + group; - resetOffsetTable.computeIfAbsent(key, k-> Maps.newConcurrentMap()).put(queueId, offset); + resetOffsetTable.computeIfAbsent(key, k -> Maps.newConcurrentMap()).put(queueId, offset); LOG.debug("Reset offset OK. Topic={}, group={}, queueId={}, resetOffset={}", topic, group, queueId, offset); // Two things are important here: // 1, currentOffsetMap might be null if there is no previous records; // 2, Our overriding here may get overridden by the client instantly in concurrent cases; But it still makes // sense in cases like clients are offline. - offsetTable.computeIfAbsent(key, k-> Maps.newConcurrentMap()).put(queueId, offset); + offsetTable.computeIfAbsent(key, k -> Maps.newConcurrentMap()).put(queueId, offset); } public boolean hasOffsetReset(String topic, String group, int queueId) {