这是我参与「第五届青训营 」伴学笔记创作活动的第 14 天
课程概要
- RPC 相关的基本概念
- RPC 框架的分层设计
- 衡量 RPC 框架的一些核心指标
- 字节内部 RPC 框架 Kitex 实践分享
基本概念
远程函数调用(RPC - Remote Procedure Calls)
需要解决的问题:
-
函数映射:
我们如何告诉对应服务我们要调用哪个函数?在本地调用中,函数体通过函数指针来指定,我们调用哪个方法,编译器就会自动帮我们调用它相应的函数指针。但是在远程调用中,函数指针是不行的,因为两个进程的地址空间完全不一样。所以函数都有自己的一个ID,在RPC时要附上这个ID,还得有个ID和函数的映射表,通过ID找到对应的函数执行.
-
数据转换为字节流:
在本地调用中,我们只需要把参数压到钱里,然后让通数自己去钱里读就行。但是在远程过程调用时,客产端跟服务端是不同的进程,不能通过内存来传递参数,这时候就需要客产端把参数并 转成一个字节流,传给服务端后,再把字节流转成自己能读取的格式。
- 网络传输
RPC概念模型
RPC的完整过程
- IDL (Interface description language) :文件IDL 通过一种中立的方式来描述接口,使得在不同平台上运行的对象和用不同语言编写的程序可以相互通信
- 生成代码:通过编译器工具把 IDL 文件转换成语言对应的静态库
- 编解码:从内存中表示到字节序列的转换称为编码,反之为解码,也常叫做序列化和反序列化
- 通信协议:规范了数据在网络中的传输内容和格式。除必须的请求/响应数据外,通常还会包含额外的元数据
- 网络传输:通常基于成熟的网络库走 TCP/UDP 传输
RPC优点
- 单一职责,有利于分工协作和运维开发
- 可扩展性强,资源使用率更优
- 故障隔离,服务的整体可靠性更高
RPC带来的问题
- 服务宕机,对方应该如何处理?
- 在调用过程中发生网络异常,如何保证消息的可达性?
- 请求量突增导致服务无法及时处理,有哪些应对措施?