如何用redis做一个可靠的消息队列

List

这是大家最常用的队列方式,就是在一个list上用lpush & rpop,如下图所示:

由于空队列的问题,要引入for循环加上一定的sleep时间,伪代码如下:

for {
  if msg:=redis.rpop();msg!=nil{
    handle(msg)
  }else{
    time.sleep(1000)
  }
}

这种方案可能存在1s处理不及时的风险(虽说在大多场景下基本没有影响)

不过redis有block算子,通过brpop实现阻塞式拉取,可以及时获得数据,伪代码如下:

for {
  # 超时时间为 0,代表无限等待
  if msg:=redis.brpop(0);msg!=nil{
    handle(msg)
  }
}

看起来很完美,解决了不处理不及时的问题,但由于redis client把超时时间设置成0后,redis server在长时间没有接受到消息的情况下,可能会判定该client为无效的链接,从而强制踢下线,所以在消息不是很密集的时候,直接设为0时,还是有一定的风险,建议保留非0的最小等待值(1s即可),伪代码如下:

for {
  if msg:=redis.
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值