X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2Fchat%2Fbackend%2Fpersistence%2Fkafka%2FKafkaChatHomeService.java;h=38aecd187e246ea906e9bb228b8e69cd00a1214c;hb=13c51b4630177e7f6649500a3d4b876a12509af6;hp=70a96bc3ddb92ae3d46ae0edec76f60df93be34b;hpb=320f2e00a39f4cb7428446223cb9fb2f37d12e25;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 70a96bc3..38aecd18 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,10 +2,8 @@ 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.ShardNotOwnedException; import lombok.extern.slf4j.Slf4j; -import org.apache.kafka.clients.consumer.Consumer; -import org.apache.kafka.clients.consumer.ConsumerRebalanceListener; -import org.apache.kafka.common.TopicPartition; import reactor.core.publisher.Flux; import reactor.core.publisher.Mono; @@ -13,125 +11,41 @@ import java.util.*; @Slf4j -public class KafkaChatHomeService implements ChatHomeService, ConsumerRebalanceListener +public class KafkaChatHomeService implements ChatHomeService { - private final Consumer consumer; - private final String topic; - private final long[] offsets; - private final MessageHandler[] handlers; - private final Map[] chatrooms; + private final ChatMessageChannel chatMessageChanel; - public KafkaChatHomeService( - Consumer consumer, - String topic, - int numShards) + public KafkaChatHomeService(ChatMessageChannel chatMessageChannel) { 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.chatMessageChanel = chatMessageChannel; } @Override - public void onPartitionsAssigned(Collection partitions) - { - consumer.endOffsets(partitions).forEach((tp, currentOffset) -> - { - 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); - handlers[partition] = new ChatRoomLoadingMessageHandlingStrategy(tp, currentOffset, unseenOffset); - }); - } - - @Override - public void onPartitionsRevoked(Collection partitions) + public Mono getChatRoom(int shard, UUID id) { - partitions.forEach(tp -> + if (chatMessageChanel.isLoadInProgress()) { - 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); - } - - @Override - public void onPartitionsLost(Collection partitions) - { - log.info("Revoked partitions: {}", partitions); - } - - private void foo() - { - Set owned = Arrays - .stream(ownedShards) - .collect( - () -> new HashSet<>(), - (set, i) -> set.add(i), - (a, b) -> a.addAll(b)); - for (int shard = 0; shard < numShards; shard++) + throw new ShardNotOwnedException(shard); + } + else { - chatrooms[shard] = owned.contains(shard) - ? new HashMap<>() - : null; + return chatMessageChanel.getChatRoom(shard, id); } - chatroomFlux - .filter(chatRoom -> - { - if (owned.contains(chatRoom.getShard())) - { - return true; - } - else - { - log.info("Ignoring not owned chat-room {}", chatRoom); - return false; - } - }) - .toStream() - .forEach(chatroom -> chatrooms[chatroom.getShard()].put(chatroom.getId(), chatroom)); - } - - @Override - public Mono putChatRoom(ChatRoom chatRoom) - { - chatrooms[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)); } @Override public Flux getChatRooms(int shard) { - return Flux.fromStream(chatrooms[shard].values().stream()); + if (chatMessageChanel.isLoadInProgress()) + { + throw new ShardNotOwnedException(shard); + } + else + { + return chatMessageChanel.getChatRooms(shard); + } } }