redis对过期事件的处理

redis支持版本:在redis 2.8版本以后对redis 中Key过期时间进行订阅和发布

应用场景:比如有效期为一个月的优惠券、限制支付时间为24小时之内等等。在Redis中,给Key设定过期(Expire)时间来可以实现这类时效性需求,并通过发布/订阅(Pub/Sub)机制来接收Key过期失效的消息以做后续处理,结合RedisHA – Sentinel,可以保障此类业务的不间断性

 我在项目中的使用情况为,用户购买一产品,分2次购买,需要将购买的消息合并后给用户发送提醒消息。

 主要逻辑为消息服务受到第一条消息后,设置xx时间过期,对同一用户,同一产品,产品数量进行累加

 接口 

ExpiredMessgaeListener 
实现MessageListener

 */
public interface ExpiredMessgaeListener  extends MessageListener {

}

ExpiredMessgaeListenerImpl 实现 ExpiredMessageListener 接口


@Service
public class ExpiredMessageListenerImpl implements ExpiredMessageListener,InitializingBean {

    @Autowired
    RedisMessageListenerContainer listenerContainer;

    @Autowired
    StringRedisTemplate redisTemplate;

    @Override
    public void onMessage(Message message, byte[] pattern) {
        System.out.println("onMessage");
        System.out.println(new String(message.getBody()));
    }

    @Override
    public void afterPropertiesSet() throws Exception {

        System.out.println("111111");
        listenerContainer.addMessageListener(this,new PatternTopic("__key*__:*"));
        listenerContainer.setConnectionFactory(redisTemplate.getConnectionFactory());
    }
}





### Redis处理 Channel 过期事件 #### 配置通知密钥空间事件 为了使 Redis 支持键过期事件的通知,需修改 `redis.conf` 文件中的配置项为 `"notify-keyspace-events Ex"`[^1]。此设置允许 Redis 对带有 TTL (Time to Live) 属性的键在其生命周期结束时发出信号。 #### 实现 Java 端监听器容器 在应用程序层面,特别是对于基于 Spring Framework 的项目而言,可以通过定义一个名为 `RedisMessageListenerContainer` 的 Bean 来创建用于接收来自 Redis 发布/订阅系统的消息监听器容器实例[^4]: ```java @Configuration public class RedisListenerConfig { @Bean RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) { final var listenerContainer = new RedisMessageListenerContainer(); listenerContainer.setConnectionFactory(connectionFactory); // 添加特定主题的消息监听者... return listenerContainer; } } ``` 上述代码片段展示了如何通过依赖注入的方式初始化并返回一个新的 `RedisMessageListenerContainer` 实例给应用上下文使用。 #### 设置监听逻辑 一旦完成了基础架构上的准备工作之后,则可以进一步编写具体的业务逻辑来响应这些由 Redis 触发的时间点变化。例如,在接收到某个指定模式下的所有匹配到的通道名称所对应的信息后执行某些操作。这通常涉及到注册自定义的消息处理器至之前提到过的容器内,并确保它们能够正确解析传入的数据流。 当键因达到其设定的有效期限而被自动清除时,如果启用了相应的通知选项 (`Ex`) ,那么将会广播一条包含该键信息的消息给所有已订阅了相应频道或模式的应用程序客户端[^3]。因此开发者可以根据实际需求设计对应的消费端行为以完成预期的任务流程。 #### 关于避免滥用 Redis过期功能作为定时任务调度工具的观点 值得注意的是,尽管技术上可行,但从最佳实践角度来看并不推荐利用 Redis 的这一特性去构建复杂的计划作业系统。因为这样做可能会带来性能瓶颈以及维护成本增加等问题;相反应该考虑采用更合适的技术栈比如 Quartz Scheduler 或 Apache Airflow 等专为此目的打造的产品来进行此类工作负载管理[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值