赞
踩
1、有这个需求一般都是集成了redis的,没有集成的,在pom.xml中加上就行
2、配置监听容器
-
- @Bean
- public RedisMessageListenerContainer redisMessageListenerContainer(RedisConnectionFactory connectionFactory) {
- RedisMessageListenerContainer container = new RedisMessageListenerContainer();
- container.setConnectionFactory(connectionFactory);
- return container;
- }
3、设置redis过期时间
- // 这里的id是唯一值 过期时间2小时
- redisTemplate.opsForValue().setIfAbsent(id, "1", 2, TimeUnit.HOURS);
4、添加监听器
- package com.zhifeng.sale.business.config;
-
- import com.zhifeng.common.SaleConstant;
- import com.zhifeng.common.mybatis.ExampleBuilder;
- import com.zhifeng.sale.business.mapper.OpenDemandMapper;
- import com.zhifeng.sale.business.model.OpenDemand;
- import com.zhifeng.sale.business.service.OpenDemandService;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.factory.annotation.Autowired;
- 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 java.util.Objects;
-
- @Component
- public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
-
- private final static Logger logger = LoggerFactory.getLogger(RedisKeyExpirationListener.class);
-
- public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
- super(listenerContainer);
- }
-
- @Override
- public void onMessage(Message message, byte[] pattern) {
- try {
- // 获取失效的key
- String key = message.toString();
- //从失效key中筛选代表订单失效的key
- if (key != null && key.startsWith(SaleConstant.KAIPING_ORDER)) {
- String openDemandId = key.substring(14);
- //业务逻辑
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
-
-
- }

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。