java延迟消息队列_ActiveMQ实现延迟消息队列

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

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

48304ba5e6f9fe08f3fa1abda7d326ab.png

1 # K 键空间通知,以__keyspace@__为前缀

2 # E 键事件通知,以__keysevent@__为前缀

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”意味着所有的事件

48304ba5e6f9fe08f3fa1abda7d326ab.png

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

1.先写一个监听器:

48304ba5e6f9fe08f3fa1abda7d326ab.png

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 }

48304ba5e6f9fe08f3fa1abda7d326ab.png

2.订阅者:

48304ba5e6f9fe08f3fa1abda7d326ab.png

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 }

48304ba5e6f9fe08f3fa1abda7d326ab.png

3.测试类:

48304ba5e6f9fe08f3fa1abda7d326ab.png

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);

}

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

4.结果:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值