spring中redisTemplate实现redis发布订阅及监听key失效

1.创建监听类实现MessageListener接口

@Component("redisMessageListener")
public class Sub implements MessageListener {
 @Autowired
 private RedisTemplate<String, Object> redisTemplate;
 @Override
 public void onMessage(Message message, byte[] pattern) {
  byte[] body = message.getBody();
  byte[] channel = message.getChannel();
  String msg = (String) redisTemplate.getValueSerializer().deserialize(body);
  String msgchannel = (String) redisTemplate.getValueSerializer().deserialize(channel);
  String msgPattern = new String(pattern);
  System.out.println("==>msg:" + msg + " ==>msgchannel:" + msgchannel + " ==>msgPattern:" + msgPattern);
 }
}

2.xml文件配置监听渠道及redis相关配置

    <bean id="redisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="hostName" value="${redis.host}"/>
        <property name="port" value="${redis.port}"/>
        <property name="password" value="${redis.password}"/>
        <property name="database" value="${redis.database}"/>
        <property name="timeout" value="${redis.timeout}"/>
        <property name="poolConfig" ref="poolConfig"/>
    </bean>
    <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxIdle" value="${redis.maxIdle}"/>
        <property name="maxTotal" value="${redis.maxTotal}"/>
        <property name="maxWaitMillis" value="${redis.maxWaitMillis}"/>
    </bean>
  
 <bean id="jackson2JsonRedisSerializer"
  class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer">
 </bean>
 <bean id="jdkSerializationRedisSerializer"
  class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
 <bean id="stringRedisSerializer"
  class="org.springframework.data.redis.serializer.StringRedisSerializer">
 </bean>
 <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
  <property name="keySerializer" ref="stringRedisSerializer" />
  <property name="hashKeySerializer" ref="stringRedisSerializer" />
  <property name="hashValueSerializer" ref="stringRedisSerializer" />
  <property name="valueSerializer" ref="stringRedisSerializer" />
  <property name="defaultSerializer" ref="stringRedisSerializer" />
  <property name="connectionFactory" ref="redisConnectionFactory" />
 </bean>
 <!-- 定义监听容器 -->
 <bean id="redisMessageListenerContainer"
  class="org.springframework.data.redis.listener.RedisMessageListenerContainer">
  <property name="connectionFactory" ref="redisConnectionFactory" />
  <!-- 任务执行器 -->
  <property name="messageListeners">
   <map>
    <entry key-ref="redisMessageListener">
     <list>
      <bean class="org.springframework.data.redis.listener.PatternTopic">
       <constructor-arg value="chat*" />
      </bean>
      <bean class="org.springframework.data.redis.listener.ChannelTopic">
       <constructor-arg value="chen1" />
      </bean>
      <bean class="org.springframework.data.redis.listener.ChannelTopic">
       <constructor-arg value="chen2" />
      </bean>
      <bean class="org.springframework.data.redis.listener.ChannelTopic">
       <constructor-arg value="__keyevent@6__:expired" />
      </bean>
     </list>
    </entry>
   </map>
  </property>
 </bean>

3.编写测试类

@RestController
@RequestMapping("/aaa/redisTest")
public class TestController {
 private Logger logger = LoggerFactory.getLogger(TestController.class);
 @Autowired
 private RedisTemplate<String, Object> redisTemplate;
 @Autowired
 private RedisUtils redisUtils;
 @RequestMapping("test")
 public R test() {
  redisTemplate.convertAndSend("chen1", "哈哈hello");
  redisTemplate.convertAndSend("chen2", "哈哈哈world");
  redisUtils.set("456", "失效了吗", 20);
  return R.ok();
 }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在 Java ,你可以使用 Redisson 这个 Redis 客户端库来实现 Redis 键的失效监听Redisson 提供了 `RKeys` 类来操作 Redis 的键,并且可以通过 `addListener` 方法添加键的监听器。以下是一个示例代码: ```java import org.redisson.Redisson; import org.redisson.api.RKeys; import org.redisson.api.RedissonClient; import org.redisson.api.listener.KeyspaceExpiredListener; public class RedisKeyExpirationListenerExample { public static void main(String[] args) { // 创建 Redisson 客户端 RedissonClient redisson = Redisson.create(); // 获取键操作对象 RKeys keys = redisson.getKeys(); // 添加键失效监听keys.addListener(new KeyspaceExpiredListener() { @Override public void onExpired(String key) { System.out.println("Key expired: " + key); // 在这里处理键失效事件 } }); // 等待键失效事件发生 try { Thread.sleep(60000); // 60秒 } catch (InterruptedException e) { e.printStackTrace(); } // 关闭 Redisson 客户端 redisson.shutdown(); } } ``` 在上述示例,我们使用 Redisson 创建了一个 Redis 客户端,并通过 `getKeys()` 方法获取了键操作对象 `RKeys`。然后,我们使用 `addListener` 方法添加了一个键失效监听器 `KeyspaceExpiredListener`,并在回调方法处理键失效事件。 你可以根据需要在回调方法编写自己的处理逻辑。在示例,我们简单地打印出了失效的键。 最后,我们通过 `Thread.sleep` 方法让程序等待一段时间,以便触发键失效事件。在实际应用,你可以根据自己的需求来决定如何触发键失效事件。 请确保你已经在项目引入了 Redisson 的依赖。你可以通过 Maven 或 Gradle 在项目的构建文件添加以下依赖: Maven: ```xml <dependency> <groupId>org.redisson</groupId> <artifactId>redisson</artifactId> <version>3.16.1</version> </dependency> ``` Gradle: ```groovy implementation 'org.redisson:redisson:3.16.1' ``` 请注意,上述示例假设 Redis 运行在本地主机。你需要根据你自己的实际情况进行适配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值