redis简介

REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。
Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Hash), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型

redis的key过期的事件触发

过期事件通过Redis的订阅与发布功能(pub/sub)来进行分发

redis服务端配置

超时的监听,并不需要自己发布,只有修改配置文件redis.conf中的:notify-keyspace-events Ex,默认为notify-keyspace-events “”

在这里插入图片描述
修改好配置文件后,redis会对设置了expire的数据进行监听,当数据过期时便会将其从redis中删除
我使用的redis的版本:
在这里插入图片描述
配置事件监听
如图

在这里插入图片描述

java实现redis中key过期事件触发

创建一个实现类继承KeyExpirationEventMessageListener

package com.focussend.weixin.utils;

import com.focussend.contacts.service.FissionMarketingService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.data.redis.connection.Message;
import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;

/**
 * Created by Administrator on 2019/2/26.
 */
@Component
class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
    public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }
    @Resource
    private FissionMarketingService fissionMarketingService;
    private Logger logger = LoggerFactory.getLogger(RedisKeyExpirationListener.class);

    private final Object fanNumUpdate = new Object();
    /**
     * 针对redis数据失效事件,进行数据处理
     * @param message
     * @param pattern
     */
    @Override
    public void onMessage(Message message, byte[] pattern) {
        // 用户做自己的业务处理即可,注意message.toString()可以获取失效的key
           String expiredKey = message.toString();
                   logger.info("此处根据对应的redis的key去处理业务逻辑");
       }
}

注入RedisMessageListenerContainer

方法一、使用xml增加的相关配置

            <bean id="redisContainer" class="org.springframework.data.redis.listener.RedisMessageListenerContainer">
                 <property name="connectionFactory" ref="jedisConnectionFactory" />
            </bean>

方法二、使用config类

/**
 * Redis缓存配置类
 */
@Configuration
public class RedisConfigurer extends CachingConfigurerSupport {
    @Bean
    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {

        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
        return container;
    }

}

测试

向redis中存入一个key和value并设置过期时间,key过期后会触发onMessage(Message message, byte[] pattern) 方法
redisCacheManagerTool.set(“test_renjiao”,“haha”,20);

总结

如果服务宕机,那么将接收不到redis推送过来的事件也就无法处理redis过期后的逻辑。我们可以采用redis+定时任务处理,这样可以避免服务宕机,Redis过期事件推送处理的问题,也能够提高系统整体性能(可以去了解一下redis的key过期策略)

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐