Spring boot 监听redis key 过期

1.第一步,修改redis配置文件内容

notify-keyspace-events "Ex"
2.项目导入redis依赖

<!-- Redis -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
3.添加配置application.yml

spring:
redis:
  # 地址
  host: 127.0.0.1
  # 端口,默认为6379
  port: 6370
  # 密码
  password: root
  # 连接超时时间
  timeout: 10s
  lettuce:
    pool:
      # 连接池中的最小空闲连接
      min-idle: 0
      # 连接池中的最大空闲连接
      max-idle: 8
      # 连接池的最大数据库连接数
      max-active: 8
      # #连接池最大阻塞等待时间(使用负值表示没有限制)
      max-wait: -1ms
4.配置监听代码

public class KeyExpiredListener extends KeyExpirationEventMessageListener {

  private static final Logger LOGGER = LoggerFactory.getLogger(KeyExpiredListener.class);

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

  @Override
  public void onMessage(Message message, byte[] pattern) {
      String channel = new String(message.getChannel(),StandardCharsets.UTF_8);
      //过期的key
      String key = new String(message.getBody(),StandardCharsets.UTF_8);
      LOGGER.info("redis key 过期:pattern={},channel={},key={}",new String(pattern),channel,key);
  }
}
5.配置配置文件代码

@Configuration
public class RedisConfiguration {

  @Autowired
  private RedisConnectionFactory redisConnectionFactory;

  @Bean
  public RedisMessageListenerContainer redisMessageListenerContainer() {
      RedisMessageListenerContainer redisMessageListenerContainer = new RedisMessageListenerContainer();
      redisMessageListenerContainer.setConnectionFactory(redisConnectionFactory);
      return redisMessageListenerContainer;
  }

  @Bean
  public KeyExpiredListener keyExpiredListener() {
      return new KeyExpiredListener(this.redisMessageListenerContainer());
  }
}

 


 

 

 

posted @   java架构师1  阅读(860)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示