java redis过期回调_redis过期监听

我的应用场景:因为业务需求,我们会每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"

0a081dc2f4a2

Ex 的解释如下:

0a081dc2f4a2

2:配置文件修改好后,重新启动redis,我的redis是用docker启动的。重新启动了容器。

3:验证redis失效监听是否好用。

进入redis容器:

docker exec -it redis /bin/sh

运行redis客户端:

redis-cli

运行监听命令:

psubscribe __keyevent@0__:expired

0a081dc2f4a2

再启动一个redis-cli

创建一个10秒后失效的reids:

setex test 10 test

0a081dc2f4a2

10秒后,可以看到监听端口可以接收到失效的redis的key.

0a081dc2f4a2

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{<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值