From: Kai Moritz Date: Fri, 17 Feb 2023 18:07:11 +0000 (+0100) Subject: WIP X-Git-Tag: kafkadata~48 X-Git-Url: http://juplo.de/gitweb/?a=commitdiff_plain;h=60aaf90c0288be9af3e73e024970d1f874bf2448;p=demos%2Fkafka%2Fchat WIP --- diff --git a/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java b/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java index 4fa567ce..556a2268 100644 --- a/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java +++ b/src/main/java/de/juplo/kafka/chat/backend/persistence/kafka/KafkaChatHomeService.java @@ -37,7 +37,7 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL for (int i=0; i< numShards; i++) { this.offsets[i] = 0l; - this.handlers[i] = new NoOpMessageHandler(i); + this.handlers[i] = new MessageHandler(new TopicPartition(topic, i)); } this.chatrooms = new Map[numShards]; } @@ -50,7 +50,7 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL { if (!tp.topic().equals(topic)) { - log.warn("Ignoring unwanted TopicPartition", tp); + log.warn("Ignoring partition from unwanted topic: {}", tp); return; } @@ -58,13 +58,26 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL long unseenOffset = offsets[partition]; log.info("Reading partition {} from {} -> {}", partition, unseenOffset, currentOffset); - handlers[partition] = new ChatRoomLoadingMessageHandler(partition, currentOffset, unseenOffset); + handlers[partition] = new ChatRoomLoadingMessageHandlingStrategy(tp, currentOffset, unseenOffset); }); } @Override public void onPartitionsRevoked(Collection partitions) { + partitions.forEach(tp -> + { + if (!tp.topic().equals(topic)) + { + log.warn("Ignoring partition from unwanted topic: {}", tp); + return; + } + + int partition = tp.partition(); + long unseenOffset = offsets[partition]; + + log.info("Reading partition {} from {} -> {}", partition, unseenOffset, currentOffset); + }); log.info("Revoked partitions: {}", partitions); } @@ -125,32 +138,37 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL } - interface MessageHandler + class MessageHandler + { + + } + + interface MessageHandlingStrategy { - MessageHandler handleMessage(Message message); + MessageHandlingStrategy handleMessage(Message message); } @RequiredArgsConstructor - class NoOpMessageHandler implements MessageHandler + class NoOpMessageHandlingStrategy implements MessageHandlingStrategy { private final TopicPartition tp; @Override - public MessageHandler handleMessage(Message message) + public MessageHandlingStrategy handleMessage(Message message) { log.warn("Not handling message {} for partition {}", message, tp); return this; } } - class ChatRoomLoadingMessageHandler implements MessageHandler + class ChatRoomLoadingMessageHandlingStrategy implements MessageHandlingStrategy { private final TopicPartition tp; private final long currentOffset; private final long unseenOffset; - ChatRoomLoadingMessageHandler(TopicPartition tp, long currentOffset, long unseenOffset) + ChatRoomLoadingMessageHandlingStrategy(TopicPartition tp, long currentOffset, long unseenOffset) { this.tp = tp; this.currentOffset = currentOffset; @@ -160,7 +178,7 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL } @Override - public MessageHandler handleMessage(Message message) + public MessageHandlingStrategy handleMessage(Message message) { // todo return this; @@ -168,12 +186,12 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL } @RequiredArgsConstructor - class DefaultMessageHandler implements MessageHandler + class DefaultMessageHandlingStrategy implements MessageHandlingStrategy { private final TopicPartition tp; @Override - public MessageHandler handleMessage(Message message) + public MessageHandlingStrategy handleMessage(Message message) { chatrooms[tp.partition()].put() return this;