Redis线程模型简介说明
我们经常说Redis是单线程--为什么大家都这样说呢?
下文笔者将阐述其具体的线程模型简介说明,如下所示
下文笔者将阐述其具体的线程模型简介说明,如下所示
Redis是一个基于Reactor模型所编写的网络事件处理器
处理器被称为文件事件处理器(file event handler)
Redis事件处理器由以下四个部分组成:
多个套接字
IO多路复用程序
文件事件分派器
事件处理器
注意事项:
由于文件事件分派器队列的消费是单线程的
所以Redis常被人说成单线程
从上图中,我们可以得出
文件事件处理器使用 I/O多路复用(multiplexing)程序来同时监听多个套接字
根据套接字目前执行的任务来为套接字关联对应的事件处理器
当被监听的套接字准备好执行连接应答(accept)、读取(read)、写入(write)、关闭(close)等操作时
与操作相对应的文件事件就会产生
这时文件事件分派器就会分派套接字给对应的事件处理器来处理这些事件
注意事项:
文件事件处理器以单线程方式运行
但通过使用 I/O 多路复用程序来监听多个套接字,
文件事件处理器既实现高性能的网络通信模型
又保持了单线程设计的简单性
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。


