X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fpersistence%2Fkafka%2FKafkaChatHomeService.java;h=e171bc5738e29f27e73afc655aa7fce699c930f8;hb=f7475320b20be8ba198ba914958e9e4dddf62e11;hp=556a22683b0d4459c70117e638abf047538578cc;hpb=60aaf90c0288be9af3e73e024970d1f874bf2448;p=demos%2Fkafka%2Fchat 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 556a2268..e171bc57 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 @@ -2,8 +2,6 @@ package de.juplo.kafka.chat.backend.persistence.kafka; import de.juplo.kafka.chat.backend.domain.ChatHomeService; import de.juplo.kafka.chat.backend.domain.ChatRoom; -import de.juplo.kafka.chat.backend.domain.Message; -import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.kafka.clients.consumer.Consumer; import org.apache.kafka.clients.consumer.ConsumerRebalanceListener; @@ -19,9 +17,9 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL { private final Consumer consumer; private final String topic; - private final long[] offsets; - private final MessageHandler[] handlers; - private final Map[] chatrooms; + // private final long[] offsets; Erst mal immer alles neu einlesen + private final Map[] kafkaChatRoomServiceMaps; + private final Map[] chatRoomMaps; public KafkaChatHomeService( @@ -32,14 +30,13 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL log.debug("Creating KafkaChatHomeService"); this.consumer = consumer; this.topic = topic; - this.offsets = new long[numShards]; - this.handlers = new MessageHandler[numShards]; - for (int i=0; i< numShards; i++) - { - this.offsets[i] = 0l; - this.handlers[i] = new MessageHandler(new TopicPartition(topic, i)); - } - this.chatrooms = new Map[numShards]; + // this.offsets = new long[numShards]; + // for (int i=0; i< numShards; i++) + // { + // this.offsets[i] = 0l; + // } + this.kafkaChatRoomServiceMaps = new Map[numShards]; + this.chatRoomMaps = new Map[numShards]; } @@ -55,9 +52,19 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL } int partition = tp.partition(); - long unseenOffset = offsets[partition]; + kafkaChatRoomServiceMaps[partition] = new HashMap<>(); // TODO: reuse! Nicht immer alles neu laden + long unseenOffset = 0; // offsets[partition]; - log.info("Reading partition {} from {} -> {}", partition, unseenOffset, currentOffset); + log.info( + "Loading messages from partition {}: start-offset={} -> current-offset={}", + partition, + unseenOffset, + currentOffset); + + consumer.seek(tp, unseenOffset); + chatRoomMaps[partition] + .values() + .stream() handlers[partition] = new ChatRoomLoadingMessageHandlingStrategy(tp, currentOffset, unseenOffset); }); } @@ -97,7 +104,7 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL (a, b) -> a.addAll(b)); for (int shard = 0; shard < numShards; shard++) { - chatrooms[shard] = owned.contains(shard) + chatRoomMaps[shard] = owned.contains(shard) ? new HashMap<>() : null; } @@ -115,86 +122,25 @@ public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceL } }) .toStream() - .forEach(chatroom -> chatrooms[chatroom.getShard()].put(chatroom.getId(), chatroom)); + .forEach(chatroom -> chatRoomMaps[chatroom.getShard()].put(chatroom.getId(), chatroom)); } @Override public Mono putChatRoom(ChatRoom chatRoom) { - chatrooms[chatRoom.getShard()].put(chatRoom.getId(), chatRoom); + chatRoomMaps[chatRoom.getShard()].put(chatRoom.getId(), chatRoom); return Mono.just(chatRoom); } @Override public Mono getChatRoom(int shard, UUID id) { - return Mono.justOrEmpty(chatrooms[shard].get(id)); + return Mono.justOrEmpty(chatRoomMaps[shard].get(id)); } @Override public Flux getChatRooms(int shard) { - return Flux.fromStream(chatrooms[shard].values().stream()); - } - - - class MessageHandler - { - - } - - interface MessageHandlingStrategy - { - MessageHandlingStrategy handleMessage(Message message); - } - - - @RequiredArgsConstructor - class NoOpMessageHandlingStrategy implements MessageHandlingStrategy - { - private final TopicPartition tp; - - @Override - public MessageHandlingStrategy handleMessage(Message message) - { - log.warn("Not handling message {} for partition {}", message, tp); - return this; - } - } - - class ChatRoomLoadingMessageHandlingStrategy implements MessageHandlingStrategy - { - private final TopicPartition tp; - private final long currentOffset; - private final long unseenOffset; - - ChatRoomLoadingMessageHandlingStrategy(TopicPartition tp, long currentOffset, long unseenOffset) - { - this.tp = tp; - this.currentOffset = currentOffset; - this.unseenOffset = unseenOffset; - - consumer.seek(tp, unseenOffset); - } - - @Override - public MessageHandlingStrategy handleMessage(Message message) - { - // todo - return this; - } - } - - @RequiredArgsConstructor - class DefaultMessageHandlingStrategy implements MessageHandlingStrategy - { - private final TopicPartition tp; - - @Override - public MessageHandlingStrategy handleMessage(Message message) - { - chatrooms[tp.partition()].put() - return this; - } + return Flux.fromStream(chatRoomMaps[shard].values().stream()); } }