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对过期事件的处理)