springboot整合redis实现key过期监控(一、单台)

一、服务器redis开启过期通知:

redis默认key过期通知是关闭的,因为它实际上是监听的(keyevent@*:expired)这个topic,会对cpu产生性能影响(可忽略不计,不必担心),要使用redis的key过期通知功能,就得更改配置:
1.更改config,默认关闭,打开注释就行
在这里插入图片描述

notify-keyspace-events Ex

2.连接redis-cli之后,输入以下命令:

config set notify-keyspace-events Ex

3.重启redis服务

二、添加依赖

1、添加maven依赖

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

2、配置文件编写

#端口号
server:
  port: 8001
  tomcat:
    uri-encoding: UTF-8
spring:
  redis:
    host: 10.0.1.51
    password:
    port: 6379
    jedis:
      pool:
        max-idle: 100
        min-idle: 1
        max-wait:
        max-active: 1000

三、编写代码

1、新增RedisListenerConfig类

@Configuration
public class RedisListenerConfig {
    /**
     *  注销的代码意思是:指定哪个具体的db库,默认是检测所有db,例如注释中检测的是db0
     * @param connectionFactory Redis连接的线程安全工厂。
     * @return RedisMessageListenerContainer
     */
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {

        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
//      container.addMessageListener(new RedisExpiredListener(), new PatternTopic("__keyevent@0__:expired"));
        return container;
    }

}

2、新增RedisKeyExpirationListener类,主要处理业务逻辑

@Component
@Slf4j
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {

    public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }

    /**
     * 针对redis数据失效事件,进行数据处理,需要注意的是只能获取到过期的key,value无法获取
     * @param message 消息
     * @param pattern 图案 - 模式匹配的信道(如果指定) - 可以为空。
     */
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String expiredKey = message.toString();
        log.info("redisKey:{}过期",expiredKey);
        //可以写自己的业务逻辑代码
    }

}

四、测试

启动springboot项目,然后连接redis服务端,使用以下命令:

PSUBSCRIBE __keyevent@0__:expired 

在这里插入图片描述

再开个窗口设置key,设置过期时间:
在这里插入图片描述
当key时间到期后可以看到第一个窗口:
在这里插入图片描述
可以看到刚才设置的key打印出来了,再次查看项目运行日志:
在这里插入图片描述
可以看到刚才代码里打出来的日志在控制器显示了

源码地址:

gitee源码地址
底下redis文件夹底下的 redis-expiration-notice 单台redis监听获取过期的key

注意:

只能监听过期key,监听不到具体value,所以需要好好设计具体key,集群会在下篇文章中

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值