javascript – Spring Websocket与Kafka集成
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – Spring Websocket与Kafka集成,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1287字,纯文字阅读大概需要2分钟。
内容图文
我正在尝试通过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(like explained here).
如何在每个传入/消费的消息上将数据从receive方法发送到KafkaController的fetchMetrics(以及因此到websocket)?
解决方法:
您应该将SimpMessagingTemplate注入KafkaReceiver并从receive()方法中使用它:
this.template.convertAndSend("/data/records", m);
请参阅Spring Framework Reference Manual中的更多信息.
内容总结
以上是互联网集市为您收集整理的javascript – Spring Websocket与Kafka集成全部内容,希望文章能够帮你解决javascript – Spring Websocket与Kafka集成所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。