当前位置:   article > 正文

redis失效key监听器_redismessagelistenercontainer

redismessagelistenercontainer

1、有这个需求一般都是集成了redis的,没有集成的,在pom.xml中加上就行

2、配置监听容器

  1. @Bean
  2. public RedisMessageListenerContainer redisMessageListenerContainer(RedisConnectionFactory connectionFactory) {
  3. RedisMessageListenerContainer container = new RedisMessageListenerContainer();
  4. container.setConnectionFactory(connectionFactory);
  5. return container;
  6. }

3、设置redis过期时间

  1. // 这里的id是唯一值 过期时间2小时
  2. redisTemplate.opsForValue().setIfAbsent(id, "1", 2, TimeUnit.HOURS);

4、添加监听器

  1. package com.zhifeng.sale.business.config;
  2. import com.zhifeng.common.SaleConstant;
  3. import com.zhifeng.common.mybatis.ExampleBuilder;
  4. import com.zhifeng.sale.business.mapper.OpenDemandMapper;
  5. import com.zhifeng.sale.business.model.OpenDemand;
  6. import com.zhifeng.sale.business.service.OpenDemandService;
  7. import org.slf4j.Logger;
  8. import org.slf4j.LoggerFactory;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.data.redis.connection.Message;
  11. import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
  12. import org.springframework.data.redis.listener.RedisMessageListenerContainer;
  13. import org.springframework.stereotype.Component;
  14. import java.util.Objects;
  15. @Component
  16. public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
  17. private final static Logger logger = LoggerFactory.getLogger(RedisKeyExpirationListener.class);
  18. public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
  19. super(listenerContainer);
  20. }
  21. @Override
  22. public void onMessage(Message message, byte[] pattern) {
  23. try {
  24. // 获取失效的key
  25. String key = message.toString();
  26. //从失效key中筛选代表订单失效的key
  27. if (key != null && key.startsWith(SaleConstant.KAIPING_ORDER)) {
  28. String openDemandId = key.substring(14);
  29. //业务逻辑
  30. }
  31. } catch (Exception e) {
  32. e.printStackTrace();
  33. }
  34. }
  35. }

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Guff_9hys/article/detail/925154
推荐阅读
相关标签
  

闽ICP备14008679号