RPC
RPC 远程过程调用 : Remote Procedure Call Protocol,是一种远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC 协议假定某些传输协议的存在,如 TCP 或 UDP,为通信程序之间携带信息数据。在 OSI 网络通信模型中,RPC 跨越了传输层和应用层。RPC 使得开发包括网络分布式多程序在内的应用程序更加容易。
RPC采用客户端(服务调用方)/服务器端(服务提供方)模式,都运行在自己的JVM中。客户端只需要引入要使用的接口,接口的实现和运行都在服务器端。
目前Java使用比较多的RPC方案主要有RMI(JDK自带)、Hessian、Dubbo以及Thrift等。
常见的RPC框架
-
RMI框架
详细参考:https://blog.youkuaiyun.com/lmy86263/article/details/72594760/ -
Dubbo:Dubbo 是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的
RPC 实现服务的输出和输入功能,可以和 Spring 框架无缝集成。Dubbo 框架,是基于容器
运行的.。容器是 Spring。官方网站 : http://dubbo.apache.org/ 阿里巴巴已经将 dubbo 框架捐献给了 Apache 软件基金会.
详细内容参考:
3.** Hessian** Hessian是一个轻量级的remotingonhttp工具,使用简单的方法提供了RMI的功能。 相比WebService,Hessian更简单、快捷。采用的是二进制RPC协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。
详细内容参考:https://blog.youkuaiyun.com/sunwei_pyw/article/details/74002351