赞
踩
redis支持版本:在redis 2.8版本以后对redis 中Key过期时间进行订阅和发布
应用场景:比如有效期为一个月的优惠券、限制支付时间为24小时之内等等。在Redis中,给Key设定过期(Expire)时间来可以实现这类时效性需求,并通过发布/订阅(Pub/Sub)机制来接收Key过期失效的消息以做后续处理,结合Redis的HA – 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());
- }
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。