JAVA实现redis超时失效key 的监听触发

过期事件通过Redis的订阅与发布功能(pub/sub)来进行分发。

而对超时的监听呢,并不需要自己发布,只有修改配置文件redis.conf中的:notify-keyspace-events Ex,默认为notify-keyspace-events "" 

 1 # K    键空间通知,以__keyspace@<db>__为前缀  
 2 # E    键事件通知,以__keysevent@<db>__为前缀  
 3 # g    del , expipre , rename 等类型无关的通用命令的通知, ...  
 4 # $    String命令  
 5 # l    List命令  
 6 # s    Set命令  
 7 # h    Hash命令  
 8 # z    有序集合命令  
 9 # x    过期事件(每次key过期时生成)  
10 # e    驱逐事件(当key在内存满了被清除时生成)  
11 # A    g$lshzxe的别名,因此”AKE”意味着所有的事件  

修改好配置文件后,redis会对设置了expire的数据进行监听,当数据过期时便会将其从redis中删除:

1.先写一个监听器:

 1 public class KeyExpiredListener extends JedisPubSub {  
 2   
 3     @Override  
 4     public void onPSubscribe(String pattern, int subscribedChannels) {  
 5         System.out.println("onPSubscribe "  
 6                 + pattern + " " + subscribedChannels);  
 7     }  
 8   
 9     @Override  
10     public void onPMessage(String pattern, String channel, String message) {  
11   
12         System.out.println("onPMessage pattern "  
13                         + pattern + " " + channel + " " + message);  
14     }  
15   
16   
17   
18 }  

 

2.订阅者:

 1 public class Subscriber {  
 2   
 3     public static void main(String[] args) {  
 4         JedisPool pool = new JedisPool(new JedisPoolConfig(), "localhost");  
 5   
 6         Jedis jedis = pool.getResource();  
 7         jedis.psubscribe(new KeyExpiredListener(), "__key*__:*");  
 8   
 9     }  
10   
11 }  

 

3.测试类:

public class TestJedis {  
  
    public static void main(String[] args) {  
        JedisPool pool = new JedisPool(new JedisPoolConfig(), "localhost");  
  
        Jedis jedis = pool.getResource();  
        jedis.set("notify", "你还在吗");  
        jedis.expire("notify", 10);  
  
    }  
}  

4.结果:

先启动订阅者,然后执行测试类,然后等待10秒之后再监听类的方法中就可以获得回调。非常需要主要的时,过期监听的管道默认是__keyevent@0__:expired,艾特后面的0表示第几个是数据库,redis默认的数据库是0~15一共16个数据库。所以如果你存入的数据库是2,那么数据接收的管道就是__keyevent@2__:expired

posted on 2017-10-30 19:40  过来啊小莲  阅读(18106)  评论(0编辑  收藏  举报

导航