RPC

RPC(Remote Procedure Call)远程过程调用框架

RPC就是要像调用本地的函数一样去调远程函数。两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上提供的函数/方法,因为不在一个内存空间,所以不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。远程过程调用能使Java编程人员能够在网络环境中分布操作。

RPC 是一种技术思想而非一种规范或协议,常见 RPC 技术和框架有:

  • 应用级的服务框架:阿里的 Dubbo/Dubbox、Google gRPC、Spring Boot/Spring Cloud。

  • 远程通信协议:RMI、Socket、SOAP(HTTP XML)、REST(HTTP JSON)。

  • 通信框架:MINA 和 Netty。

完整的RPC框架

包含:服务发现、负载、容错、网络传输、序列化等组件

其中“RPC协议”指明了程序如何进行网络传输的序列化

RPC核心功能

  • 服务寻址

  • 数据流的序列化和反序列化

  • 网络传输

服务寻址

通过服务注册中心通过映射的方式调用服务,查询对方服务都有哪些实例。在RPC中所有函数都有自己的ID,在所有的进程中都是唯一的。

客户端在做远程过程调用时,需要附上此ID。当客户端需要进行远程调用时,找出相应的 Call ID,然后把它传给服务端,服务端也通过查表,来确定客户端需要调用的函数,然后执行相应函数的代码。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值