redis中key过期时触发事件

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过期策略)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值