Chinaunix首页 | 论坛 | 博客
  • 博客访问: 549294
  • 博文数量: 298
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 3077
  • 用 户 组: 普通用户
  • 注册时间: 2019-06-17 10:57
文章分类

全部博文(298)

文章存档

2022年(96)

2021年(201)

2019年(1)

我的朋友

分类: Java

2021-08-19 13:16:11

 1、引用redis的包


点击(此处)折叠或打开

  1. <dependency>
  2.     <groupId>org.springframework.boot</groupId>
  3.     <artifactId>spring-boot-starter-data-redis</artifactId>
  4. </dependency>
2、配置redis监听容器

点击(此处)折叠或打开

  1. import org.springframework.context.annotation.Bean;
  2. import org.springframework.context.annotation.Configuration;
  3. import org.springframework.data.redis.connection.RedisConnectionFactory;
  4. import org.springframework.data.redis.listener.RedisMessageListenerContainer;

  5. @Configuration
  6. public class RedisListenerConfig {
  7.     //from fhadmin.cn
  8.     @Bean
  9.     RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
  10.         RedisMessageListenerContainer container = new RedisMessageListenerContainer();
  11.         container.setConnectionFactory(connectionFactory);
  12.         return container;
  13.     }
  14. }
3、创建redis过期监听

点击(此处)折叠或打开

  1. @Component
  2. public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
  3.     //from fhadmin.cn
  4.     @Override
  5.     public void onMessage(Message message, byte[] pattern) {
  6.         // 过期key
  7.         String expiredKey = message.toString();
  8.         System.out.println(expiredKey + "过期了");
  9.         // 下面可以通过redis工具获取值或者执行业务逻辑
  10.     }

  11.     public RedisKeyExpirationListener(RedisMessageListenerContainer redisMessageListenerContainer ){
  12.         super(redisMessageListenerContainer);
  13.     }
  14. }
4、测试是否可行


这个时候你可以搞个api测试下,设置过期事件为30秒,看下当key过期时,是否会正常被监听到。

5、注意事项

注意:监听器能监听到redis中过期的key是有个要求的,必须在redis配置文件里面设置能够监听到key过期事件,配置文件去目录下找,配置如下:

image-20210604235727511

阅读(653) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~