目录
前言
Muduo网络库的设计特点,是一个多reactor多线程模型。在这种模型中,使用了一个main reactor主反应堆来负责监听和接受新的网络连接,sub reactor子反应堆们来负责监听和处理读写事件等。
关于muduo网络库的多reactor多线程模型
1. Main reactor(主反应堆)
· Acceptor在main reactor中创建监听套接字并绑定到特定端口。
· Acceptor将监听套接字注册到main reactor的eventLoop上,即注册套接字相应的回调函数。
· EventLoop将监听套接字加入到epoll的监控列表中。
2. Epoll监听
· Epoll实例开始监听所有注册的监听套接字上的事件。
3. 新连接请求
· 当有新连接请求到达监听套接字时,epoll检测到这个事件。
· Epoll通过回调机制通知main reactor的eventLoop。
4. Acceptor回调
· Main reactor的eventLoop接收到通知后,调用注册在其上的acceptor的回调函数。
· Acceptor的回调函数创建新的连接套接字,并通常将新套接字的读写事件注册到子reactor的eventLoop中。
5. 子reactor
· 新连接套接字被分发给一个子reactor的eventLoop。
· 子reactor的eventLoop将新套接字注册到其内部的epoll实例上。
6. Epoll事件处理
· Epoll实例在子reactor中开始监听新套接字上的读写事件。
· 当有新的事件(如数据可读或可写)发生时,epoll通知子reactor的eventLoop。
7. 事件分发
· 子reactor的eventLoop接收到通知后,根据事件类型调用相应的回调函数或事件处理器。
· 这些回调函数或事件处理器处理实际的读写操作或其他网络事件。
总结
One loop one thread即一个线程一个事件循环,就是每个线程上的eventloop。这种设计方式允许多个连接被分派到多个线程中,从而充分利用多核CPU的并行处理能力。