Reactor反应器模式 (epoll)

Posted xudong-bupt

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Reactor反应器模式 (epoll)相关的知识,希望对你有一定的参考价值。

1. 背景

最近在看redis源码,主体流程看完了。
在网上看到了reactor模式,看了一下,其实我们经常使用这种模式。

2. 什么是reactor模式

反应器设计模式(Reactor pattern)是一种为处理并发服务请求,并将请求提交到一个或者多个服务处理程序的事件设计模式。
当客户端请求抵达后,服务处理程序使用多路分配策略,由一个非阻塞的线程来接收所有的请求,然后派发这些请求至相关的工作线程进行处理。
简单说,就是如何处理多个客户端的并发请求的解决模式。

3. 一般实现方法

3.1 epoll管理大量客户端(可读、可写)

处理大量客户端请求,不能去挨个轮训,这个要使用epoll。
epoll由于select, poll。这个网上有很多资料。

3.2 请求的单线程处理(redis中的特殊处理)

到达服务端的请求,redis代码中,使用单线程处理。
redis使用就是单线程既要处理连接、也要处理请求,因为redis全内存,避免了线程间加锁、切换等。

3.3 请求的多线程处理(更一般的架构处理)

通常架构中都是采用多线程来处理到达服务器的请求。
将请求放到无锁队列中,处理线程循环来请求任务即可。
因为服务器代码中,可能会访问第三方存储等长耗时处理。用多线程加速。

技术分享图片

4. 参考

以上是关于Reactor反应器模式 (epoll)的主要内容,如果未能解决你的问题,请参考以下文章

Reactor-反应器模式

IO设计模式之Reactor和Proactor

Reactor模式 和epoll

Reactor模式和Proactor模式

libevent & Reactor模式

epoll高度封装reactor,几乎所有可见服务器的底层框架