Kafka入门到精通(四)-SpringBoot+Kafka

一丶IDEA创建一个空项目

二丶添加相关依赖

复制代码
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.kafka</groupId>
            <artifactId>spring-kafka</artifactId>
            <version>2.9.13</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.28</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.alibaba.fastjson2</groupId>
            <artifactId>fastjson2</artifactId>
            <version>2.0.12</version>
        </dependency>
    </dependencies>

三丶编写简单生产者

复制代码
    /**
     * 简单的生产者消费者
     * @param message
     */
    @GetMapping("/kafka/normal/message")
    public void sendNormalMessage(@RequestParam("message") String message) {
        log.info("======================="+message);
        kafkaTemplate.send("sb_topic", 0, System.currentTimeMillis(), "key1", message);
    }

四丶编写简单消费者

复制代码
@Component
public class KafkaConsumer {
 
    //监听消费
    //@KafkaListener(topics = {"sb_topic"})
    @KafkaListener(topics = {"sb_topic","callbackOne_topic"}, groupId = "testGroup")
    public void onNormalMessage(ConsumerRecords<String,Object> records) {
        for (ConsumerRecord<String, Object> record : records) {
            System.out.printf("offset = %d, key = %s, value = %s\n", record.offset(), record.key(), record.value());
        }
    }
 
}

这里有个坑,ConsumerRecord如果不加s会报错,我之间在借鉴他人代码的时候出现的,不知道是不是版本问题。我也刚用kafka,正在研究哈哈,见谅见谅;

postman请求:

成功:

结尾:目前只是一个简单的demo,后续我在完善,我也正在学习这玩意儿,哈哈,喜欢的朋友点个赞收藏吧;

相关推荐
毕设源码-钟学长3 分钟前
【开题答辩全过程】以 基于Hadoop的新闻推荐系统为例,包含答辩的问题和答案
大数据·hadoop·分布式
无心水6 分钟前
【分布式利器:腾讯TSF】2、腾讯微服务框架TSF实战指南:Spring Boot零侵入接入与容器化部署全流程
java·spring boot·分布式·微服务·springcloud·分布式利器·腾讯tsf
霍格沃兹测试开发学社测试人社区6 分钟前
Playwright测试策略:顺序、并行及分布式执行方案
分布式·自动化·playwright
ai_xiaogui25 分钟前
从实体转行到本地AI:AIStarter 完美收官,Panelai 开启分布式算力管理新篇章
人工智能·分布式
苏小瀚31 分钟前
[JavaEE] Spring Boot 日志
java·spring boot·后端
予枫的编程笔记31 分钟前
Elasticsearch 全面解析:从原理到实战的分布式搜索引擎指南
java·开发语言·分布式·后端·elasticsearch·搜索引擎·全文检索
木子江L34 分钟前
SpringBoot集成RabbitMQ消息中间件
java·spring boot·rabbitmq·java-rabbitmq
Gao_xu_sheng35 分钟前
IDEA恢复删除模块pom文件
java·spring boot·idea
计算机毕设指导638 分钟前
基于微信小程序的直播带货商品数据分析系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
凹凸曼说我是怪兽y3 小时前
Redis分布式锁详细实现演进与Redisson深度解析
数据库·redis·分布式