zoukankan      html  css  js  c++  java
  • redis 异步队列 mysql_面试题:使用过 Redis 做异步队列么,你是怎么用的?

    使用过 Redis 做异步队列么,你是怎么用的?

    一般使用 list 结构作为队列,rpush 生产消息,lpop 消费消息。当 lpop 没有消息的时候,要适当 sleep 一会再重试。不但客户端

    的 CPU 能降下来,Redis 的 QPS 也降下来了。

    如果对方追问可不可以不用 sleep 呢?

    用 blpop/brpop 替代前面的 lpop/rpop,list 还有个指令叫 blpop阻塞读在队列没有数据的时候,会立即进入休眠状态,一旦数据到来,则立刻醒过来。消

    息的延迟几乎为零。

    如果对方追问能不能生产一次消费多次呢?

    使用 pub/sub 主题订阅者模式,可以实现1:N 的消息队列。

    如果对方追问 pub/sub 有什么缺点?

    在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如 RabbitMQ等。Redis5.0 新增了 Stream 数据结构,这个功能给 Redis 带来了持久化消息队列。

    如果对方追问 redis 如何实现延时队列?

    延时队列可以通过 Redis 的 zset(有序列表) 来实现。我们将消息序列化成一个字符串作为 zset 的 value,这个消息的到期处理时间作为 score,然后用多个线程轮询 zset 获取到期的任务进行处理,多个线程是为了保障可用性,万一挂了一个线程还有其它线程可以继续处理。
    ————————————————
    原文链接:https://blog.csdn.net/weixin_42310558/article/details/113997337

  • 相关阅读:
    windows下查看端口占用情况及关闭相应的进程
    python学习中的一些“坑”
    python 中一些关键字的区别
    linux下配置Tomcat开机启动
    windows 下的python 安装pycrypto
    'redis-server' 不是内部或外部命令,也不是可运行的程序或批处理文件
    怎么学习代码
    crx文件不能安装,提示无效的安装包
    回调函数
    koa-router的作用
  • 原文地址:https://www.cnblogs.com/gaosf/p/14456645.html
Copyright © 2011-2022 走看看