一、阻塞队列
创建了一个生产者线程和一个消费者线程。生产者线程向队列中放入元素,消费者线程从队列中取出元素。我们可以看到,当队列为空时,消费者线程会被阻塞,直到生产者线程向队列中放入新的元素。
二、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放入页面