彻底明白RPC框架
来源:互联网 发布:宝山行知外国语学校 编辑:程序博客网 时间:2024/05/16 06:41
RPC框架,首先了解什么叫RPC,为什么要RPC,RPC是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。
比如说,一个方法可能是这样定义的:
Employee getEmployeeByName(String fullName)
那么:
为什么RPC呢?就是无法在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如比如不同的系统间的通讯,甚至不同的组织间的通讯。由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用,
RPC的协议有很多,比如最早的CORBA,Java RMI,Web Service的RPC风格,Hessian,Thrift,甚至Rest API。
比如说,一个方法可能是这样定义的:
Employee getEmployeeByName(String fullName)
那么:
- 首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。
- 第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如基于Web服务协议栈的RPC,就要提供一个endpoint URI,或者是从UDDI服务上查找。如果是RMI调用的话,还需要一个RMI Registry来注册服务的地址。
- 第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。
- 第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。
- 第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用
为什么RPC呢?就是无法在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如比如不同的系统间的通讯,甚至不同的组织间的通讯。由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用,
RPC的协议有很多,比如最早的CORBA,Java RMI,Web Service的RPC风格,Hessian,Thrift,甚至Rest API。
阅读全文
0 0
- 彻底明白RPC框架
- 彻底明白javaIO (转)
- 彻底明白操作系统环境变量
- 彻底明白IP地址
- 彻底明白IP地址
- 彻底明白操作系统环境变量
- 彻底弄明白IRP
- 彻底明白IO包
- 彻底弄明白十六进制
- 彻底明白红黑树
- dynamic_cast彻底明白了~
- 彻底搞明白layout_weight
- 彻底明白IP地址
- 彻底明白IP地址
- 教你彻底弄明白Executor框架线程池任务执行的全过程
- RPC框架
- RPC框架
- RPC 框架
- 细谈那年初做自媒体经验分享
- vi基本操作命令
- Java学习——面向对象之多态
- Java 征途:行者的地图
- 并发编程
- 彻底明白RPC框架
- nodejs基础 Stream流2
- 广东问果、广东国笔高精鍊的新思维模式是什么?
- python 实现pat Sort with Swap(0,*)
- sql语句分为三类(DML,DDL,DCL)-介绍
- Python激活码
- [面试要点]java io编程
- Executor详细介绍 打造基于Executor的Web服务器
- Quartz与spring结合 定时任务