我使用的是Windows下的Redis服务,所以一下Redis设置都是在Windows平台进行。

1、修改Redis配置文件

1.1:Windows下的Redis存在两个配置文件

修改带有service的配置文件才会有效。

打开配置文件,找到下面一行代码:

notify-keyspace-events ""

然后修改配置,如下图配置:

很简单,替换注释一下就好。

 

2、重启Redis服务

重启Redis服务有两种方式:

1、直接win+R,打开运行对话框,输入Services.msc,打开服务列表。然后找到Redis服务重启就好了。

2、打开cmd命令窗口,输入下面命令:

   redis-server --service-stop

关闭成功!!

3.打开cmd命令窗口,输入下面命令:

  redis-server --service-start

开启成功!!

 

3、在springboot项目中配置Redis配置

 我的项目使用的是springboot2.0.5,所以一下配置适用springboot2.0.5项目,其他版本没试过。

两种方式:

第一种:指定:__keyevent@0__:expired,监听指定的db键的过期事件。

Redis配置第一步:

/**
 * TODO Redis配置
 * @author zhuzhen
 * @date 16:20 2018/12/18
 */
@Configuration
@EnableCaching
public class RedisConfig extends CachingConfigurerSupport {

    /**
     * TODO 监听 Redis键过期事件
     * @author zhuzhen
     * @date 14:38 2018/12/21
     * @param connectionFactory
     * @return org.springframework.data.redis.listener.RedisMessageListenerContainer
     */
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
        container.addMessageListener(new RedisExpiredListener(), new PatternTopic("__keyevent@0__:expired"));
        return container;
    }

}

Redis配置第二步:

实现MessageListener接口:

/**
 * @author zhuzhen
 * @version 1.0
 * @description TODO 自定义Redis过期监听事件
 * @className com.nongcai.rabbitmq.demo.redis.RedisExpiredListener
 * @date 2018/12/21 14:42
 */
public class RedisExpiredListener implements MessageListener {

    @Override
    public void onMessage(Message message, byte[] bytes) {
        // 建议使用: valueSerializer
        byte[] body = message.getBody();
        byte[] channel = message.getChannel();
        //Redis数据的键
        String redisId = new String(body);

        System.out.println("onMessage >> " );
        System.out.println(String.format("channel: %s \n body: %s \n bytes: %s"
                ,new String(channel), new String(body), new String(bytes)));

    }
}

 

 第二种:监听所有的db键的过期事件。

Redis配置第一步:配置监听bean

 /**
     * TODO 监听 Redis键过期事件
     * @author zhuzhen
     * @date 14:38 2018/12/21
     * @param connectionFactory
     * @return org.springframework.data.redis.listener.RedisMessageListenerContainer
     */
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {

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

Redis配置第二步:

/**
 * @author zhuzhen
 * @version 1.0
 * @description TODO 监听所有db的过期事件__keyevent@*__:expired"
 * @className com.nongcai.rabbitmq.demo.redis.RedisKeyExpirationListener
 * @date 2018/12/21 14:39
 */
@Component
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {

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

    @Override
    public void onMessage(Message message, byte[] pattern) {
        // 用户做自己的业务处理即可,注意message.toString()可以获取失效的key
        System.out.println("message>>>  " + message);
        System.out.println("pattern>>>  " + new String(pattern));
        String expiredKey = message.toString();
        System.out.println("Redis的键:" + expiredKey);

    }
}

自此,监听Redis键过期事件配置完成。

spring关于Redis文章地址:https://spring.io/guides/gs/messaging-redis/

 

posted on 2018-12-21 15:41  十七年蝉  阅读(4225)  评论(3编辑  收藏  举报