go微服务-RPC简介及原理介绍

RPC简介及原理介绍


文章目录

  • RPC简介及原理介绍
    • RPC简介
    • RPC设计组成
    • RPC原理及调用步骤
    • RPC涉及到的相关技术


RPC简介

RPC是Remote Procedure Call Protocol单词首字母的缩写,简称为:RPC,翻译成中文叫远程过程调用协议,指的是调用远端服务器上的程序的方法整个过程。


RPC设计组成

RPC技术在架构设计上有四部分组成,分别是:客户端、客户端存根、服务端、服务端存根。

  • 客户端(Client):服务调用发起方,也称为服务消费者。

  • 客户端存根(Client Stub):该程序运行在客户端所在的计算机机器上,主要用来存储要调用的服务器的地址,另外,该程序还负责将客户端请求远端服务器程序的数据信息打包成数据包,通过网络发送给服务端Stub程序;其次,还要接收服务端Stub程序发送的调用结果数据包,并解析返回给客户端。

  • 服务端(Server):远端的计算机机器上运行的程序,其中有客户端要调用的方法。

  • 服务端存根(Server Stub):接收客户Stub程序通过网络发送的请求消息数据包,并调用服务端中真正的程序功能方法,完成功能调用;其次,将服务端执行调用的结果进行数据处理打包发送给客户端Stub程序。


RPC原理及调用步骤

RPC具体的调用步骤图如下:

go微服务-RPC简介及原理介绍_第1张图片上述RPC调用过程具体描述为:

  • 1、客户端想要发起一个远程过程调用,首先通过调用本地客户端Stub程序的方式调用想要使用的功能方法名;

  • 2、客户端Stub程序接收到了客户端的功能调用请求,将客户端请求调用的方法名,携带的参数等信息做序列化操作,并打包成数据包。

  • 3、客户端Stub查找到远程服务器程序的IP地址,调用Socket通信协议,通过网络发送给服务端。

  • 4、服务端Stub程序接收到客户端发送的数据包信息,并通过约定好的协议将数据进行反序列化,得到请求的方法名和请求参数等信息。

  • 5、服务端Stub程序准备相关数据,调用本地Server对应的功能方法进行,并传入相应的参数,进行业务处理。

  • 6、服务端程序根据已有业务逻辑执行调用过程,待业务执行结束,将执行结果返回给服务端Stub程序。

  • 7、服务端Stub程序**将程序调用结果按照约定的协议进行序列化,**并通过网络发送回客户端Stub程序。

  • 8、客户端Stub程序接收到服务端Stub发送的返回数据,**对数据进行反序列化操作,**并将调用返回的数据传递给客户端请求发起者。

  • 9、客户端请求发起者得到调用结果,整个RPC调用过程结束。


RPC涉及到的相关技术

我们来对上述RPC调用中涉及到的技术做一个总结和分析:

1、动态代理技术: 上文中我们提到的Client Stub和Sever Stub程序,在具体的编码和开发实践过程中,都是使用动态代理技术自动生成的一段程序。

2、序列化和反序列化: 在RPC调用的过程中,我们可以看到数据需要在一台机器上传输到另外一台机器上。在互联网上,所有的数据都是以字节的形式进行传输的。而我们在编程的过程中,往往都是使用数据对象,因此想要在网络上将数据对象和相关变量进行传输,就需要对数据对象做序列化和反序列化的操作。

  • 序列化:把对象转换为字节序列的过程称为对象的序列化,也就是编码的过程。

  • 反序列化:把字节序列恢复为对象的过程称为对象的反序列化,也就是解码的过程。

上节学习过的Protobuf协议就可以对数据做序列化和反序列化编码操作,其在RPC框架中使用很广泛。


你可能感兴趣的:(go微服务,微服务)