关于muduo网络库的多reactor多线程模型

目录

前言

关于muduo网络库的多reactor多线程模型

1. Main Reactor(主反应堆)

2. Epoll监听

3. 新连接请求

4. Acceptor回调

5. 子Reactor

6. Epoll事件处理

7. 事件分发

总结


前言

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的并行处理能力。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值