监听Redis 缓存过期(Key 失效)事件

很多业务场景,例如订单过期自动删除,订单几天后自动好评,这些常用操作可以通过定时任务,数据库轮询做,但是订单量大的情况可能会对数据库产生大的压力。

所以今天介绍的就是 redis 缓存过期通知。

注: 楼主技术提升的同时, 这个博文失效吧, 这个只能适用于单机redis, 订单过期删除这些操作还是通过rocketMq, 或者时间轮, 或者Zset进行操作吧


1. 事件通过 Redis 的订阅与发布功能(pub/sub)来进行分发, 故需要开启 redis 的事件监听与发布

2. 修改 redis.conf 文件 

打开 notify-keyspace-events Ex 的注释,开启过期通知功能

 
  1. # 我这边开启事件监听

  2. notify-keyspace-events Ex

3. 重启redis , 即可测试失效事件的触发, 监听获取的值为 key
 


进入redis-client,进入监听

 
  1. 127.0.0.1:6379> PSUBSCRIBE __keyevent@*__:expired

  2. Reading messages... (press Ctrl-C to quit)

  3. 1) "psubscribe"

  4. 2) "__keyevent@*__:expired"

  5. 3) (integer) 1

再打开一个 redis-client,发送过期数据

 
  1. 127.0.0.1:6379> setex test 2 2

  2. OK

 

返回之前的 client,监听到过期事件

 
  1. 127.0.0.1:6379> PSUBSCRIBE __keyevent@*__:expired

  2. Reading messages... (press Ctrl-C to quit)

  3. 1) "psubscribe"

  4. 2) "__keyevent@*__:expired"

  5. 3) (integer) 1

  6. 1) "pmessage"

  7. 2) "__keyevent@*__:expired"

  8. 3) "__keyevent@0__:expired"

  9. 4) "test"

至此,redis 环境配置完毕;


接下来是服务端配置监听事件:

/**
 * Description: Redis超时监听器
 * User: zhouzhou
 * Date: 2019-04-07
 * Time: 9:02 PM
 */
@Service
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
 
 
    private static Logger log = LoggerFactory.getLogger(RedisKeyExpirationListener.class);
 
    public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }
 
    @Override
    public void onMessage(Message message, byte[] pattern) {
        //获取过期的key
        String expireKey = message.toString();
        System.out.println("终于失效了");
        log.debug("key is:"+ expireKey);
        System.out.println(expireKey);
        //这里还可以根据key的自定义前缀来判断执行哪个条件
        //......
    }
}

配置 redis 远程监听配置:
/**
 * Description: redis 远程监听
 * User: zhouzhou
 * Date: 2019-04-17
 * Time: 3:04 PM
 */
@Configuration
public class RedisListenerConfig {
 
 
    @Bean
    RedisMessageListenerContainer listenerContainer(RedisConnectionFactory connectionFactory) {
        RedisMessageListenerContainer listenerContainer = new RedisMessageListenerContainer();
        listenerContainer.setConnectionFactory(connectionFactory);
        return listenerContainer;
    }
 
    @Bean
    KeyExpirationEventMessageListener redisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        return new RedisKeyExpirationListener(listenerContainer);
    }
 
    
}

redis 连接的配置我就不发了。

启动项目,当我们再次通过 redis-client 进行测试;可以看到 console打印一下日志:

 
  1. 终于失效了

  2. test

  • 5
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值