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)来进行分发。

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

image.png

修改好配置文件后,redis会对设置了expire的数据进行监听,当数据过期时便会将其从redis中删除

我使用的redis的版本:
image.png

配置事件监听
如图:


image.png

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

a.创建一个实现类继承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去处理业务逻辑");
       }
}

b. 注入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过期策略)。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • RedisRedis命令参考网址:http://doc.redisfans.com/ Redis 简介Redis ...
    野柳阅读 4,844评论 0 9
  • 我的应用场景:因为业务需求,我们会每10分钟从kafka得到数据开始处理,这时就会存在一种情况,如果kafka数据...
    szgl_lucifer阅读 12,079评论 0 3
  • 缓存是最直接有效提升系统性能的手段之一。个人认为用好用对缓存是优秀程序员的必备基本素质。 本文结合实际开发经验,从...
    Java小生阅读 4,298评论 1 3
  • 重点参考链接: http://www.cnblogs.com/wangyuyu/p/3786236.html Re...
    Kevin_Junbaozi阅读 6,549评论 0 21
  • 提灯 金桔觉得自己好像被一股气流托着,正在缓缓下降,正难过着的金桔慢慢降落在了地上,她坐了下来,坐在地上。这地面给...
    smile啦啦啦啦阅读 3,505评论 0 7

友情链接更多精彩内容