仿牛客论坛项目day7|Kafka

一、阻塞队列

创建了一个生产者线程和一个消费者线程。生产者线程向队列中放入元素,消费者线程从队列中取出元素。我们可以看到,当队列为空时,消费者线程会被阻塞,直到生产者线程向队列中放入新的元素。

二、Kafka入门

发布、订阅

三、spring整合Kafka

首先,需要在项目的pom.xml中添加对Spring Kafka的依赖。然后,可以通过配置类或application.properties来配置Kafka生产者和消费者。接着,使用KafkaTemplate发送消息和使用@KafkaListener注解来监听和接收消息。

四、发送系统通知

功能拆解:

具体实现:

构造生产者与消费者

生产者:将得到的event发给指定主题

消费者:将event转换为message对象,再将message存入数据库

调用producer

comment controller:生成event,调用生产者的fire event方法。有人点赞时就会将event发出,到消息队列里,消费者监听到后会将event转换为message对象,再将message存入数据库。

like controller:生成event,调用生产者的fire event方法。

follow controller:生成event,调用生产者的fire event方法。

五、显示系统通知

message表里有新的点赞、评论、关注。现在增加将这些数据显示在系统通知页面的功能。

service:增加查询message通知的方法

controller:将查到的message放入页面

相关推荐
Qiuner43 分钟前
Spring Boot 配置文件高级实战指南 热更新/动态配置/安全加密/分布式同步/环境变量注入
spring boot·分布式·安全
无心水1 小时前
【分布式利器:事务】4、SAGA模式:长事务的最佳选择?
分布式·seata·分布式事务·saga模式·tcc·分布式利器·长事务
2501_941810832 小时前
5G技术:如何推动智慧城市建设,提升城市管理与生活质量
kafka
lang201509283 小时前
Kafka延迟操作机制深度解析
分布式·python·kafka
zl9798998 小时前
RabbitMQ-下载安装与Web页面
linux·分布式·rabbitmq
2501_9416243311 小时前
云计算与边缘计算:未来数字化转型的双引擎
kafka
while(努力):进步12 小时前
人工智能的未来:如何改变我们的工作与生活
kafka
zl97989915 小时前
RabbitMQ-Work Queues
分布式·rabbitmq
2501_9414037615 小时前
人工智能与机器学习:未来科技的核心驱动力
kafka
回家路上绕了弯17 小时前
日增千万数据:数据库表设计与高效插入存储方案
分布式·后端