PhxRPC源码分析(三) RPC

本文详细分析了PhxRPC的源码,涵盖RPC原理、DataFlow、统计与QoS、Worker线程、WorkPool、IO处理及服务器组件。每个部分阐述了它们的功能和交互方式,例如DataFlow的请求与响应队列,HshaServerStat的运行状态统计,Worker线程的工作模式,以及HshaServerAcceptor如何接受连接。通过理解这些组件,可以深入理解PhxRPC的内部工作流程。
摘要由CSDN通过智能技术生成

RPC

整个RPC的定义基本都在hsha_server这个文件。主要有一下几个类:

  • DataFlow :数据流,所有请求和应答分别保存在两个线程安全的队列中。
  • HshaServerStat HshaServerQos: 统计运行状态,独立线程。
  • Worker :独立的工作线程,如果是协程模式,每个worker会有多个协程。
  • WorkerPool:工作池,管理Worker
  • HshaServerUnit:独立线程的工作单元,每个单元都有一个WorkerPool ,UThreadEpollSchedulerDataFlow
  • 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) {
   
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值