kafka使用基本语句

该文指导如何操作Kafka,包括启动Zookeeper和Kafka服务,创建名为file-image-topic的topic,向该topic写入消息,以及从topic读取消息。此外,还展示了列出所有Kafkatopic的命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.启动zookeeper

2.启动卡夫卡

3.创建topic 名为file-image-topic

kafka-topics.bat -create --bootstrap-server localhost:9092 --replication-factor 1 --partitions 3 --topic file-image-topic

4.在file-image-topic中写消息

kafka-console-producer.bat --broker-list localhost:9092 --topic file-image-topic

示例:

5.读取file-image-topic中的消息(需要另外打开一个cmd窗口)

kafka-console-consumer.bat --bootstrap-server localhost:9092 --topic file-image-topic --from-beginning

示例: 

6.显示kafka中已有的topic

kafka-topics.bat --list --bookstrap-server localhost:9092

 

### 如何在 Spring Boot 中集成和使用 Kafka #### 1. 添加 Maven 或 Gradle 依赖 为了使 Spring Boot 应用程序能够与 Kafka 进行交互,需引入 `spring-kafka` 依赖。对于基于 Maven 的项目,在 pom.xml 文件中加入如下配置[^1]: ```xml <dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> </dependency> ``` 而对于采用 Gradle 构建工具的情况,则应在 build.gradle 文件内添加相应语句: ```groovy implementation 'org.springframework.kafka:spring-kafka' ``` #### 2. 配置 application.properties 或 application.yml 接下来要设置连接到 Kafka Broker 所必需的各项参数。如果偏好 properties 格式的文件,那么可以这样写入属性值: ```properties spring.kafka.bootstrap-servers=localhost:9092 spring.kafka.consumer.group-id=my-group spring.kafka.consumer.auto-offset-reset=earliest spring.kafka.consumer.key-deserializer=org.apache.kafka.common.serialization.StringDeserializer spring.kafka.consumer.value-deserializer=org.apache.kafka.common.serialization.StringDeserializer spring.kafka.producer.key-serializer=org.apache.kafka.common.serialization.StringSerializer spring.kafka.producer.value-serializer=org.apache.kafka.common.serialization.StringSerializer ``` 而当选用 YAML 方式表达时,相应的设定会显得更为简洁明了: ```yaml spring: kafka: bootstrap-servers: localhost:9092 consumer: group-id: my-group auto-offset-reset: earliest key-deserializer: org.apache.kafka.common.serialization.StringDeserializer value-deserializer: org.apache.kafka.common.serialization.StringDeserializer producer: key-serializer: org.apache.kafka.common.serialization.StringSerializer value-serializer: org.apache.kafka.common.serialization.StringSerializer ``` #### 3. 创建 Kafka 生产者组件 定义一个用于发送消息至指定主题的服务类。这里展示了一个简单的例子,其中包含了向特定 topic 发送字符串类型消息的方法[^3]。 ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.kafka.core.KafkaTemplate; import org.springframework.stereotype.Service; @Service public class ProducerService { private final KafkaTemplate<String, String> kafkaTemplate; @Autowired public ProducerService(KafkaTemplate<String, String> kafkaTemplate) { this.kafkaTemplate = kafkaTemplate; } public void sendMessage(String message){ kafkaTemplate.send("test-topic",message); } } ``` #### 4. 实现 Kafka 消费者逻辑 编写监听器方法接收来自某个或某些 topics 上的消息,并对其进行处理。下面给出的是一个基本的消费者实现案例。 ```java import org.springframework.kafka.annotation.KafkaListener; import org.springframework.stereotype.Component; @Component public class ConsumerService { @KafkaListener(topics = "test-topic") public void listen(String message){ System.out.println("Received Message: "+message); } } ``` 通过上述步骤即可完成 Spring Boot 和 Apache Kafka 的基础集成工作。当然实际开发过程中还可能涉及到更多复杂场景下的需求满足,比如事务支持、重试机制等高级特性的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值