在springboot中对kafka进行读写的示例代码
发布时间 - 2026-01-11 03:08:12 点击率:次springboot对kafka的client很好的实现了集成,使用非常方便,本文也实现了一个在springboot中实现操作kafka的demo。

1.POM配置
只需要在dependencies中增加 spring-kafka的配置即可。完整效果如下:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.4.RELEASE</version>
</parent>
<properties>
<java.version>1.8</java.version>
<spring-kafka.version>1.2.2.RELEASE</spring-kafka.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<!-- spring-kafka -->
<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>
<version>${spring-kafka.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka-test</artifactId>
<version>${spring-kafka.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
2.生产者
参数配置类,其参数卸载yml文件中,通过@Value注入
package com.dhb.kafka.producer;
import org.apache.kafka.clients.producer.ProducerConfig;
import org.apache.kafka.common.serialization.StringSerializer;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.core.DefaultKafkaProducerFactory;
import org.springframework.kafka.core.KafkaTemplate;
import org.springframework.kafka.core.ProducerFactory;
import java.util.HashMap;
import java.util.Map;
@Configuration
public class SenderConfig {
@Value("${kafka.bootstrap-servers}")
private String bootstrapServers;
@Bean
public Map<String,Object> producerConfigs() {
Map<String,Object> props = new HashMap<>();
props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,this.bootstrapServers);
props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG,StringSerializer.class);
props.put(ProducerConfig.ACKS_CONFIG,"0");
return props;
}
@Bean
public ProducerFactory<String,String> producerFactory() {
return new DefaultKafkaProducerFactory<>(producerConfigs());
}
@Bean
public KafkaTemplate<String,String> kafkaTemplate() {
return new KafkaTemplate<String, String>(producerFactory());
}
@Bean
public Sender sender() {
return new Sender();
}
}
消息发送类
package com.dhb.kafka.producer;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.kafka.core.KafkaTemplate;
@Slf4j
public class Sender {
@Autowired
private KafkaTemplate<String,String> kafkaTemplate;
public void send(String topic,String payload) {
log.info("sending payload='{}' to topic='{}'",payload,topic);
this.kafkaTemplate.send(topic,payload);
}
}
3.消费者
参数配置类
package com.dhb.kafka.consumer;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.common.serialization.StringDeserializer;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.annotation.EnableKafka;
import org.springframework.kafka.config.ConcurrentKafkaListenerContainerFactory;
import org.springframework.kafka.core.ConsumerFactory;
import org.springframework.kafka.core.DefaultKafkaConsumerFactory;
import java.util.HashMap;
import java.util.Map;
@Configuration
@EnableKafka
public class ReceiverConfig {
@Value("${kafka.bootstrap-servers}")
private String bootstrapServers;
public Map<String,Object> consumerConfigs() {
Map<String,Object> props = new HashMap<>();
props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG,bootstrapServers);
props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG,StringDeserializer.class);
props.put(ConsumerConfig.GROUP_ID_CONFIG,"helloword");
return props;
}
@Bean
public ConsumerFactory<String,String> consumerFactory() {
return new DefaultKafkaConsumerFactory<>(consumerConfigs());
}
@Bean
public ConcurrentKafkaListenerContainerFactory<String,String> kafkaListenerContainerFactory() {
ConcurrentKafkaListenerContainerFactory<String,String> factory =
new ConcurrentKafkaListenerContainerFactory<>();
factory.setConsumerFactory(consumerFactory());
return factory;
}
@Bean
public Receiver receiver() {
return new Receiver();
}
}
消息接受类
package com.dhb.kafka.consumer;
import lombok.extern.slf4j.Slf4j;
import org.springframework.kafka.annotation.KafkaListener;
import java.util.concurrent.CountDownLatch;
@Slf4j
public class Receiver {
private CountDownLatch latch = new CountDownLatch(1);
public CountDownLatch getLatch() {
return latch;
}
@KafkaListener(topics = "${kafka.topic.helloworld}")
public void receive(String payload) {
log.info("received payload='{}'",payload);
latch.countDown();
}
}
3.web测试类
定义了一个基于http的web测试接口
package com.dhb.kafka.web;
import com.dhb.kafka.producer.Sender;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@RestController
@Slf4j
public class KafkaProducer {
@Autowired
Sender sender;
@RequestMapping(value = "/sender.action", method = RequestMethod.POST)
public void exec(HttpServletRequest request, HttpServletResponse response,String data) throws IOException{
this.sender.send("testtopic",data);
response.setCharacterEncoding("UTF-8");
response.setContentType("text/json");
response.getWriter().write("success");
response.getWriter().flush();
response.getWriter().close();
}
}
4.启动类及配置
package com.dhb.kafka;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class KafkaApplication {
public static void main(String[] args) {
SpringApplication.run(KafkaApplication.class,args);
}
}
application.yml
kafka: bootstrap-servers: 192.168.162.239:9092 topic: helloworld: testtopic
程序结构:
包结构
5.读写测试
通过执行KafkaApplication的main方法启动程序。然后打开postman进行测试:
运行后返回success
生产者日志:
消费者日志:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# springboot
# kafka
# 读写
# 滴滴二面之Kafka如何读写副本消息的
# 实现了
# 很好
# 只需
# 要在
# 大家多多
# 进行测试
# core
# context
# Configuration
# Bean
# util
# HashMap
# Map
# DefaultKafkaProducerFactory
# KafkaTemplate
# ProducerFactory
# annotation
# clients
# ProducerConfig
# apache
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何快速选择适合个人网站的云服务器配置?
如何确认建站备案号应放置的具体位置?
如何在自有机房高效搭建专业网站?
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
Java解压缩zip - 解压缩多个文件或文件夹实例
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
iOS发送验证码倒计时应用
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
简历在线制作网站免费版,如何创建个人简历?
如何为不同团队 ID 动态生成多个“认领值班”按钮
大同网页,大同瑞慈医院官网?
LinuxShell函数封装方法_脚本复用设计思路【教程】
php增删改查怎么学_零基础入门php数据库操作必知基础【教程】
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
想要更高端的建设网站,这些原则一定要坚持!
如何在Windows环境下新建FTP站点并设置权限?
免费网站制作appp,免费制作app哪个平台好?
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
js实现点击每个li节点,都弹出其文本值及修改
zabbix利用python脚本发送报警邮件的方法
Laravel中的Facade(门面)到底是什么原理
如何选择PHP开源工具快速搭建网站?
北京网站制作的公司有哪些,北京白云观官方网站?
Laravel怎么连接多个数据库_Laravel多数据库连接配置
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
详解MySQL数据库的安装与密码配置
智能起名网站制作软件有哪些,制作logo的软件?
Swift开发中switch语句值绑定模式
再谈Python中的字符串与字符编码(推荐)
深圳网站制作平台,深圳市做网站好的公司有哪些?
敲碗10年!Mac系列传将迎来「触控与联网」双革新
Laravel Debugbar怎么安装_Laravel调试工具栏配置指南
,交易猫的商品怎么发布到网站上去?
,南京靠谱的征婚网站?
大型企业网站制作流程,做网站需要注册公司吗?
黑客入侵网站服务器的常见手法有哪些?
高端建站如何打造兼具美学与转化的品牌官网?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
如何在宝塔面板创建新站点?
Linux系统运维自动化项目教程_Ansible批量管理实战
如何快速生成ASP一键建站模板并优化安全性?
如何制作一个表白网站视频,关于勇敢表白的小标题?
Laravel如何实现文件上传和存储?(本地与S3配置)
php结合redis实现高并发下的抢购、秒杀功能的实例

