**通信-RPC模型**

通信模型分为4种
远程过程调用(RPC)、远程方法调用(RMI)、面向消息中间件(MOM)以及流(stream)。这里主要讨论远程过程调用(RPC)通信模型。
RPC的目的在于将消息传递的大部分复杂性隐藏,比较实用与客户-服务器应用程序。
定义:当机器A上的进程调用机器B上的进程时,A上的调用进程被挂起,B上被调用进程开始执行。调用方可以通过使用参数将信息传递给被调用方,而后通过传回的结果得到信息。
思想:尽可能使远程过程调用具有与本地调用相同的形式。
问题1:调用过程和被调用过程运行在不同的机器上,他们在不同的地址空间执行从而带来复杂性。
问题2: 需要进行复杂参数和结果的传递。
问题3: 双方任何一发发生崩溃而引发各种问题。

介绍:这里引入4个名词:客户端、客户端存根、服务器端、服务器存根
这里客户端和服务器端不做解释(如果这个都不知道,感觉也没必要浪费时间继续看下去的)
客户存根:将参数打包成消息,并请求发送消息到服务器
服务器存根:是客户存根在服务器端的等价物,用来将通过网络输入的请求转存为本地过程调用。
![这里写图片描述] (https://img-blog.youkuaiyun.com/20161026195141219)
客户与服务器之间的RPC原理
远程过程调用的一般步骤
这里写图片描述
(1)客户过程以正常的方式调用客户存根
(2)客户存根生成一个消息,之后调用本地操作系统
(3)客户端操作系统将消息发送给远程服务器操作系统
(4)服务器操作系统将消息交给服务器存根
(5)服务器存根将参数提取,并调用服务器
(6)服务器执行要求的操作,操作完成将结果返回给服务器存根
(7)服务器存根将结果打包成一个消息,之后调用服务器本地系统
(8)服务器操作系统将消息发送给客户操作系统
(9)客户操作系统将消息交给客户存根
(10)客户存根将结果从消息中提取出来,返回给调用它的客户过程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值