我的应用场景:因为业务需求,我们会每10分钟从kafka得到数据开始处理,这时就会存在一种情况,如果kafka数据没有传递过来,我们是不是要通过一种方式知道数据没传递通知我们。在这里我选用的模式是redis提供的观察者模式。
原理:从kafka得到的数据保存到redis中,key的失效时间可以自定义配置(我定义15分钟失效),每次从kafka得到数据都去刷新redis,这样如果kafka每次都传递数据,redis就不会失效,如果不传递数据,redis就会失效,然后通过redis的监听器得到这个失效的redis再进行后续处理(我们这边是进行邮件报警)
1:配置redis的失效监听,需要修改redis.conf配置文件
增加:notify-keyspace-events "Ex"
配置文件中找到notify-keyspace-events,修改成notify-keyspace-events "Ex"
Ex 的解释如下:
2:配置文件修改好后,重新启动redis,我的redis是用docker启动的。重新启动了容器。
3:验证redis失效监听是否好用。
进入redis容器:
docker exec -it redis /bin/sh
运行redis客户端:
redis-cli
运行监听命令:
psubscribe __keyevent@0__:expired
再启动一个redis-cli
创建一个10秒后失效的reids:
setex test 10 test
10秒后,可以看到监听端口可以接收到失效的redis的key.
4:java代码编写,pom.xml引入
org.springframework.boot
spring-boot-starter-data-redis
5:配置redis的config,配置了两种方式,第一种方式是支持@Cacheable创建redis.第二种方式是直接引用redis提供的StringRedisTemplate类来调用redis的set和get方法。
第一种方式的配置文件写法:RedisCacheConfig.java
@Configuration
public class RedisCacheConfig{<