开发者社区 问答 正文

我们怎么才能知道Delayed Queue中的消息到期了呢?

我们怎么才能知道Delayed Queue中的消息到期了呢?

展开
收起
kun坤 2020-04-23 20:06:05 414 分享 版权
1 条回答
写回答
取消 提交回答
  • 每个Worker定时扫描,ZSET的最小执行时间,如果到了就取出,这个方法在消息少的时候特别浪费资源,在消息量多的时候,由于轮训不及时导致延时的时间不准确。

    因为第一个方法问题比较多,所以这里借鉴了Timer中的一些思想,通过wait-notify可以达到一个比较好的延时效果,并且资源也不会浪费,第一次的时候还是获取ZSET中最小的时间,然后wait(执行时间-当前时间),这样就不需要浪费资源到达时间时会自动响应,如果当前ZSET有新的消息进入,并且比我们等待的消息还要小,那么直接notify唤醒,重新获取这个更小的消息,然后又wait,如此循环。

    2020-04-23 20:06:12
    赞同 展开评论
问答地址: