繁体   English   中英

Spring Websocket与Kafka的集成

[英]Spring Websocket integration with Kafka

我正在尝试通过Spring MVC项目中的Spring-Websockets将消耗的Kafka数据发送到前端(JavaScript)。

为了建立服务器与客户端之间的通信,我需要执行以下操作。

客户端(app.js)

function connect() {
    var socket = new SockJS('/kafka-data-websocket');
    stompClient = Stomp.over(socket);
    stompClient.connect({}, function (frame) {
        console.log('Connected: ' + frame);
        stompClient.send("/app/fetchData");
        stompClient.subscribe('/data/records', function (message) {
            console.log(JSON.parse(message.body).content);
        });
    });
}

服务器(KafkaController.java)

@Controller
public class KafkaController {

    @MessageMapping("/fetchData")
    @SendTo("/data/records")
    public String fetchMetrics() {
        //...
    }
}

为了使用来自特定Kafka主题的数据,我使用@KafkaListener注释,如下所示:

public class KafkaReceiver {
    @KafkaListener(topics = "mytopic")
    public void receive(ConsumerRecord<?, ?> record) {
        MyRecord m = new MyRecord(new Long(record.offset()), record.key().toString(), record.value().toString());
           //...
    }
}

我有一个适当的KafkaConfig类,其中包含所有必需的bean( 如此处所述 )。

如何在每个传入/已用消息上将数据从receive方法发送到KafkaController的fetchMetrics (进而发送到Websocket)?

您应该将SimpMessagingTemplate注入KafkaReceiver并从receive()方法中使用它:

 this.template.convertAndSend("/data/records", m);

在Spring Framework Reference Manual中查看更多信息。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM