Kafka入门示例

KafKa基本介绍

Kafka是开源的分布式事件流平台,被数千家公司用于高性能数据管道、流分析、数据集成和任务关键型应用程序。Kafka是由Scala写成的一个分布式消息队列。

它包括Topic、Consumer、Producer,Broker(包含多个Partition)。

同一个Topic的消息会有多个分区多个副本,一个分区可以被多个消息者组消费,但只能由一个消费者组中一个Consumer消费。

Kafka的多分区多副本机制的好处

Kafka可以将同一topic的多条消息分散到多个partition中,而这些partition是分布于不同的Broker(服务器)上的,能提高并发处理的能力。一个Partition可指定多年replica数,能极大提高消息存储的安全性和容灾能力。

发布/订阅消息示例

源码地址

bsmn-springboot-demos: springboot相关示例代码 - Gitee.com

依赖

<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>
</dependency>

生产者

package com.bsmn.springboot.kafka.producer;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.stereotype.Service;
@Service
public class KafkaProducer {
private final KafkaTemplate<String, String> kafkaTemplate;
public KafkaProducer(KafkaTemplate<String, String> kafkaTemplate) {
this.kafkaTemplate = kafkaTemplate;
}
public void sendMessage(String topic, String message) {
kafkaTemplate.send(topic, message);
}
}

消息者

package com.bsmn.springboot.kafka.consumer;
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Service;
@Service
public class KafkaConsumer {
@KafkaListener(topics = "my-topic", groupId = "my-group")
public void listen(String message) {
System.out.println("Received message: " + message);
}
}
}
}

posted on   白首码农  阅读(12)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
< 2025年3月 >
23 24 25 26 27 28 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 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示