Spring Boot 集成 Kafka
Spring Boot 集成 Kafka
1.1. 版本说明
| 构件 | 版本 |
|---|---|
| spring-boot | 2.7.18 |
| spring-kafka | 2.8.11 |
1.2. Spring 配置
spring:
application:
name: spring-kafka-basic-demo
kafka:
bootstrap-servers: localhost:9092
producer:
client-id: spring-kafka-basic-demo-producer
consumer:
client-id: spring-kafka-basic-demo-consumer
group-id: spring-kafka-basic-demo-group
kafka:
topic:
basic-demo-topic: spring-kafka-basic-demo-topic
1.5. 测试
@Component
@Slf4j
public class SpringKafkaBasicDemo implements ApplicationRunner {
@Value("${kafka.topic.basic-demo-topic}")
private String basicDemoTopic;
@Resource
private KafkaTemplate<String, String> kafkaTemplate;
@Override
public void run(ApplicationArguments args) throws Exception {
String payload = "Hello Topic!";
kafkaTemplate.send(basicDemoTopic, payload);
log.info("sent a message, topic: {}, payload: {}", basicDemoTopic, payload);
}
@KafkaListener(topics = "${kafka.topic.basic-demo-topic}")
public void listen(Message<String> message) {
log.info(
"received a message, topic: {}, offset: {}, payload: {}",
message.getHeaders().get(KafkaHeaders.RECEIVED_TOPIC),
message.getHeaders().get(KafkaHeaders.OFFSET),
message.getPayload()
);
}
}
启动程序,控制台将输出:
sent a message, topic: spring-kafka-basic-demo-topic, payload: Hello Topic!
received a message, topic: spring-kafka-basic-demo-topic, offset: 13, payload: Hello Topic!
本文来自博客园,作者:Jason,转载请注明原文链接:https://www.cnblogs.com/jason207010/p/18609229
浙公网安备 33010602011771号