仿牛客论坛项目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放入页面

相关推荐
丸卜1 小时前
Hadoop复习(二)
大数据·hadoop·分布式
斯普信专业组2 小时前
RabbitMQ仲裁队列高可用架构解析
分布式·架构·rabbitmq
计算机毕设定制辅导-无忧学长2 小时前
RabbitMQ 可靠性保障:消息确认与持久化机制(二)
分布式·rabbitmq·ruby
玹之又玹2 小时前
Kafka 客户端连接机制的一个典型陷阱
java·kafka
livemetee5 小时前
Kafka KRaft + SSL + SASL/PLAIN 部署文档
分布式·kafka·ssl
NON-JUDGMENTAL5 小时前
使用 PySpark 从 Kafka 读取数据流并处理为表
分布式·kafka·linq
计算机毕设定制辅导-无忧学长6 小时前
RabbitMQ 与其他 MQ 的对比分析:Kafka/RocketMQ 选型指南(一)
kafka·rabbitmq·rocketmq
weixin_307779136 小时前
RabbitMQ性能调优:关键技术、技巧与最佳实践
分布式·性能优化·rabbitmq
向哆哆6 小时前
Java消息队列应用:Kafka、RabbitMQ选择与优化
java·kafka·java-rabbitmq
今天又在摸鱼13 小时前
rabbitmq的高级特性
分布式·rabbitmq