IE盒子

搜索
查看: 112|回复: 19

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

[复制链接]

2

主题

5

帖子

8

积分

新手上路

Rank: 1

积分
8
发表于 2023-3-4 08:19:43 | 显示全部楼层 |阅读模式
做rpc选型时候,有人说到grpc,想在网上找一些grpc c/c++的源码分析来帮助理解,发现除了官方doc里带的文档外寥寥无几(也可能是自己没找到?)。只能自己捋起袖子“啃一啃”grpc的源码。
在进入正题之前,有必要简短的说一下我的分析思路,以免给一些读者带来困惑。

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





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

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

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





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

回复

使用道具 举报

0

主题

6

帖子

7

积分

新手上路

Rank: 1

积分
7
发表于 2023-3-4 08:20:03 | 显示全部楼层
图画得很形象
回复

使用道具 举报

0

主题

4

帖子

0

积分

新手上路

Rank: 1

积分
0
发表于 2023-3-4 08:20:09 | 显示全部楼层
梳理很清晰
回复

使用道具 举报

2

主题

7

帖子

11

积分

新手上路

Rank: 1

积分
11
发表于 2023-3-4 08:20:21 | 显示全部楼层
谢谢
回复

使用道具 举报

2

主题

4

帖子

6

积分

新手上路

Rank: 1

积分
6
发表于 2023-3-4 08:20:31 | 显示全部楼层
好,打算看这个入门了
回复

使用道具 举报

3

主题

9

帖子

15

积分

新手上路

Rank: 1

积分
15
发表于 2023-3-4 08:21:24 | 显示全部楼层
grpc的通信是http2协议啊,怎么就是基于socket的epoll?请教了
回复

使用道具 举报

1

主题

6

帖子

7

积分

新手上路

Rank: 1

积分
7
发表于 2023-3-4 08:21:53 | 显示全部楼层
epoll是linux system call,grpc在epoll上封装了http2协议,epoll在网络层,http2在应用层
回复

使用道具 举报

3

主题

9

帖子

16

积分

新手上路

Rank: 1

积分
16
发表于 2023-3-4 08:22:06 | 显示全部楼层
感谢回复。另外多请教下,多进程之间用grpc比用单纯的socket通信 好在哪里?
回复

使用道具 举报

2

主题

6

帖子

10

积分

新手上路

Rank: 1

积分
10
发表于 2023-3-4 08:22:56 | 显示全部楼层
好处太多了,更高效的协议,收发的容错处理
回复

使用道具 举报

1

主题

4

帖子

6

积分

新手上路

Rank: 1

积分
6
发表于 2023-3-4 08:23:24 | 显示全部楼层
请问“更高效的协议”应该如何理解?我理解这里grpc采用的protobuf序列化这和反序列化是非常高效的。单就下层的通信协议而言,socket和http2而言,应该socket更高效一些吧。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表