原文:https://blog.csdn.net/hawkerou/article/details/65449957
1、异步通信核心模块EventCenter+Epoll
概述
EventCenter是Async异步消息通信的核心模块,通过事件/回调模型向上提供异步消息通信,每个Async下的worker线程负责处理一个EventCenter的事件集合。EventCenter针对不同类型的事件使用不同的事件监听来处理事件回调。
详细设计
事件类型
目前EventCenter共支持4种类型的事件,每个worker线程在进入事件处理逻辑的时候,会分别对这4种事件类型的事件进行处理
- file_events:fd类事件
- time_events/event_map:定时器类事件
- external_events/external_num_events:外部事件(时间为0的定时事件)
- pollers:轮询类事件(目前是DPDk模块在使用)
事件操作
event_center对外提供创建/删除:fd、time、external 3种类型的事件,poller事件则需要EventCenter::Poller的派生类自行实现poll方法。下面介绍下4种事件的监听方式:
-
fd类事件
支持dpdk、epoll、kqueue、select4种监听方式。以epoll为例子,则是封装的epoll_create/epoll_ctl/epoll_wait接口来向EventCenter提供监听操作接口。(定义在EventEpoll.cc/h)
-
time类事件
通过定时器来监听
-
外部事件
外部事件实际上是定时时间为0的时间,也就是立马执行,设计这个事件的主要目的切换线程上下文,来避免死锁问题。
- pollers
派生类的poll轮询
事件的处理
每个worker的线程负责处理EventCente