zoukankan      html  css  js  c++  java
  • 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. 参考

  • 相关阅读:
    bzoj3224
    [洛谷日报第62期]Splay简易教程 (转载)
    bzoj1588
    codeforces467C
    codeforces616B
    codeforces379C
    codeforces545C
    codeforces285C
    codeforces659C
    快读代码level.2
  • 原文地址:https://www.cnblogs.com/xudong-bupt/p/9463804.html
Copyright © 2011-2022 走看看