潘志宝
2024-12-25 e2b151e9bed2b6798cfc1ed499e98bcb0665d6ec
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package com.iailab.framework.websocket.core.sender.kafka;
 
import lombok.RequiredArgsConstructor;
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.kafka.annotation.KafkaListener;
 
/**
 * {@link KafkaWebSocketMessage} 广播消息的消费者,真正把消息发送出去
 *
 * @author iailab
 */
@RequiredArgsConstructor
public class KafkaWebSocketMessageConsumer {
 
    private final KafkaWebSocketMessageSender rabbitMQWebSocketMessageSender;
 
    @RabbitHandler
    @KafkaListener(
            topics = "${iailab.websocket.sender-kafka.topic}",
            // 在 Group 上,使用 UUID 生成其后缀。这样,启动的 Consumer 的 Group 不同,以达到广播消费的目的
            groupId = "${iailab.websocket.sender-kafka.consumer-group}" + "-" + "#{T(java.util.UUID).randomUUID()}")
    public void onMessage(KafkaWebSocketMessage message) {
        rabbitMQWebSocketMessageSender.send(message.getSessionId(),
                message.getUserType(), message.getUserId(),
                message.getMessageType(), message.getMessageContent());
    }
 
}