RPC
整个RPC的定义基本都在hsha_server
这个文件。主要有一下几个类:
DataFlow
:数据流,所有请求和应答分别保存在两个线程安全的队列中。HshaServerStat
HshaServerQos
: 统计运行状态,独立线程。Worker
:独立的工作线程,如果是协程模式,每个worker
会有多个协程。WorkerPool
:工作池,管理Worker
。HshaServerUnit
:独立线程的工作单元,每个单元都有一个WorkerPool
,UThreadEpollScheduler
和DataFlow
。HshaServerIO
:在HshaServerUnit
线程处理IO事件。HshaServer
:server对象,有多个工作单元。HshaServerAcceptor
:接受连接,工作在主线程。
运行起来有一个accept线程,每个unit有一个IO线程,多个worker线程。
各个模块之间的关系如下
DataFlow
DataFlow
包含request和response队列,并附加了时间戳和参数指针。
HshaServerStat HshaServerQos
独立线程负责统计运行信息,线程绑定为CallFunc
函数,使用了设置超时时间的条件变量,超时时间为1s,这样如果没有通知则每秒统计一次。
Worker
独立工作线程,绑定为Worker::Func
void Worker::Func() {
if (uthread_count_ == 0)