面试之二:Redis是单线程还是多线程?以及处理模型。

 
Redis是单线程还是多线程?以及处理模型。
  • 线程:单线程
  • 处理模型:参考书《Redis 设计与实现》P151-152
  • 上述图片解释说明:
    • 1、文件事件:
      • 是对套接字操作的抽象,每当一个套接字准备好执行操作(连接应答,写入,读取)时,就会产生一个文件事件。
    • 2、文件处理器(单线程)的4个部分:(模型见上图)
      • 套接字:
        • 代表一个一个的客户端连接;
      • IO多路复用程序:
        • 同时监听多个套接字,并向文件事件分派器传送那些产生了事件的套接字;
      • 文件事件分派器:
      • 事件处理器:
    • 3、多个文件事件并发出现时,如何处理?(队列)
      • IO多路复用程序会将所有产生事件的套接字都放到一个队列里,然后通过该队列,以有序,同步,每次一个套接字的方式传送给文件事件分派器;
      • 当上一个套接字产生的事件被处理完毕,IO多路复用程序才会继续传送下一个套接字
 
posted @ 2019-04-03 08:18  不无聊  阅读(6756)  评论(0编辑  收藏  举报