前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >GRPC-C++源码分析(一)--网络模型

GRPC-C++源码分析(一)--网络模型

原创
作者头像
路小饭
修改2019-04-19 17:53:21
4.2K1
修改2019-04-19 17:53:21
举报
文章被收录于专栏:C++开源框架源码分析

做rpc选型时候,有人说到grpc,想在网上找一些grpc c/c++的源码分析来帮助理解,发现除了官方doc里带的文档外寥寥无几(也可能是自己没找到?)。只能自己捋起袖子“啃一啃”grpc的源码。

在进入正题之前,有必要简短的说一下我的分析思路,以免给一些读者带来困惑。

  1. 先整体后部分。框架结构、线程模型一开始就会说明。阅读一份陌生的代码,就像破解一个复杂案件,如果已经有人把大体走向和结果都告诉了你,你只需要根据主要线索去补充细节,想必会容易很多
  2. 这不是一份源码细节分析的文章,更侧重流程分析,这会帮助你更快的学习源码细节
  3. 代码选取的是grpc当前的master分支

1 普适性的rpc网络模型

上面的图是一个极简的网络模型图,当前大部分rpc的网络库都要经历上面的部分。

  1. bind常规操作
  2. listen描述符建立成功后会注册到epoll模型,等待链接接入
  3. accept成功建立
  4. accept描述符注册到epoll模型,等待请求
  5. 请求到来,描述符可读,处理请求,一般包括的协议的解析
  6. 请求送到逻辑模块或者叫做业务模块进行处理
  7. 逻辑处理完成等待发送
  8. epoll调度完成结果发送

2 grpc网络模型

grpc会启动多个线程的epoll来处理描述符。

  • 得益于SO_REUSEPORT参数,同一个listenfd可以被放到多个epoll中进行监听
  • 当一个链接成功建立后会生成acceptfd,这个acceptfd会被随机的分配到现有的epoll中,目前grpc的分配策略是轮询(round-robin)

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 普适性的rpc网络模型
  • 2 grpc网络模型
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档