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); } } } }
本文来自博客园,作者:白首码农,转载请注明原文链接:https://www.cnblogs.com/bsmn/p/18583619
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下