Redis部分设置

修改配置文件redis.conf(Windows为redis.windows.conf)

  • 打开该配置文件(位置取决于自己的安装位置),找到Event notification部分。
  • 将notify-keyspace-events Ex的注释打开或者添加该配置,其中E代表Keyevent,此种通知会返回key的名字,x代表超时事件。
  • 如果notify-keyspace-events ""配置没有被注释的话要注释掉,否则不会生效。
  • 保存后重启redis,一定要使用当前配置文件重启,例如src/redis-server redis.conf

SpringBoot部分设置

添加redis依赖

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

在全局配置文件application中添加redis配置

spring.redis.host = localhost
spring.redis.port=6379
spring.redis.database=0
spring.redis.listen-pattern = __keyevent@0__:expired

listen-pattern填写超时时间,意思为springboot将监听redis发出的超时键空间通知。下划线前面的0代表redis的0号数据库。

创建listener

public class TopicMessageListener implements MessageListener {
    @Override
    public void onMessage(Message message, byte[] bytes) {
        byte[] body = message.getBody();
        byte[] channel = message.getChannel();
        System.out.println(new String(body));
        System.out.println(new String(channel));
    }
}

其中message为redis返回的通知,body为超时的key的名字,channel为超时事件

创建listener配置类

@Configuration
public class RedisListenerConfiguration {

//将listener注入到容器中,防止调用被管理的bean出现空指针
    @Bean
    public TopicMessageListener getTopicListener(){
        return new TopicMessageListener();
    }

    @Bean
    public RedisMessageListenerContainer getListenerContainer(RedisConnectionFactory connectionFactory){
        //创建连接容器
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        //放入redis连接
        container.setConnectionFactory(connectionFactory);
        //写入需要被监听的类型,即超时监听
        Topic topic = new PatternTopic("__keyevent@0__:expired");
        container.addMessageListener(getTopicListener(), topic);
        return container;
    }
}

之后当有键值过期时,redis会发送通知被上面的TopicMessageListener接收,在该类中即可调用对应的业务方法进行业务处理。


guomz
16 声望1 粉丝

不求做完人,只求做凡人。