分布式之RPC

RPC基础

何为RPC?

rpc,即为远程过程调用。

为什么要RPC?

因为,两个不同的服务器上的服务提供的方法不在一个内存空间,所以,需要通过网络编程才能传递方法调用所需要的参数。并且,方法调用的结果也需要通过网络编程来接收。但是如果手动网络编程实现这个调用过程的话工作量很大,因此需要考虑底层传输方式、序列化方式。

rpc能帮助我们做什么呢?

通过RPC可以帮助我们调用远程计算机上某个服务的方法,就像调用本地方法一样简单。并且不需要了解底层网络编程的具体细节。

RPC的原理是什么呢?

RPC的核心功能分为6个部分实现的:

1.客户端:调用远程方法的一端

2.客户端stub(桩):这其实就是一个代理类。代理类就是调用方法、类、方法参数等信息传递到服务端。

3.网络传输:网络传输就是你要把你调用的方法的信息比如说参数传输到服务端,然后服务端执行完之后再把返回结果通过网络传输给你传输回来。

4.服务端的stub:这个桩不是代理类。服务端stub实际指的是接收到客户端执行方法请求后,去指定对应方法然后返回结果给客户端的类。

5.服务端:提供远程方法的一端。

1.服务消费端以本地调用的方式调用远程服务

2.客户端stub接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体(序列化):RpcRequest;

3.客户端stub找到远程服务地址,并将消息发送到服务提供端;

4.服务端stub将受到的消息反序列化为java对象:RpcRequest;

5.服务端stub根据RpcRequest中的类、方法、方法参数等信息调用本地的方法;

6.服务端stub得到方法执行结果并将组装成能够进行网络传输的消息的题

RpcResponse(序列化)发送至消费方;

7.客户端stub接收到消息将消息反序列化为java对象:RpcResponse,这样得到最终结果。over!;

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值