1 RPC协议分析比较
1.1 RMI
1.1.1 概述
SUN官方,基于TCP协议
允许多个服务绑定一个端口
cachestub为true时,性能提升30%
1.1.2 优点
高效稳定,特别是大数据量的情况下
1.1.3 演化
RMI stub-编译期(JDK5.0前)
动态代理RMI-运行期(JDK5.0后)
1.1.4 缺点
仅限于JAVA
1.1.5 通讯过程
· 客户端发起请求,请求转交至RMI客户端的stub类;
· stub类将请求的接口、方法、参数等信息进行序列化;
· 基于socket将序列化后的流传输至服务器端;
· 服务器端接收到流后转发至相应的skelton类;
· skelton类将请求的信息反序列化后调用实际的处理类;
· 处理类处理完毕后将结果返回给skelton类;
· Skelton类将结果序列化,通过socket将流传送给客户端的stub;
· stub在接收到流后反序列化,将反序列化后的Java Object返回给调用者。
·
1.1.6 抓包
服务注册与调用默认为两个端口,服务请求包较大
连接:
报文交互:
请求报文内容:
1.2 自定义报文
1.2.1 目的
希望(或者说渴望)大家(不同业务,不同语言)用统一的协议提供服务,为未来彼此间无缝调用提供一种可能性,重要性堪比秦始皇统一货币。
1.2.2 机制
跨语言(任何编程语言都可以应用和理解)
简单,高效(要求快于RMI、hessian)
数据长度应该尽可能的小
基于TCP/IP,长链接
1.2.3 协议参考
参考报文头:
报文长 4 消息总长度,包含报文头及报文体
命令或响应类型 4
消息流水号 4
1.3 Hessian
1.3.1 基于二进制Http协议
1.3.2 开源,多语言支持
1.3.3 抓包
需要发送Http报文头,请求包数据量小
交互:
请求报文:
1.5.1 性能不是一般地差
1.5.2 HTTP、高安全、XML语义
1.6 Phprpc(免费)
1.6.1 高效序列化、低效RPC
1.6.2 简单
1.6.3Hprose(收费) 试用版本高效,不稳定;正式版有待检验
1.7 综合比较图
协议/比较项
|
RMI
|
自定义
|
Hessian
|
|
Phprpc
|
WebService
|
底层协议
|
TCP/IP
|
TCP/IP
|
HTTP(二进制)
|
|
Http
|
HTTP
|
稳定性
|
高
|
较高
|
较高
|
|
|
高
|
性能(每秒循环处理数)
|
高(980)
|
理论上最高
|
高(1010)
|
|
较低(313)
|
低(100以内)
|
跨语言/开放性
|
仅限于JAVA、不需二次开发
|
跨语言、需要开发。协议相对封闭
|
跨语言、不需二次开发
|
|
跨语言、不需二次开发
|
跨语言、不需二次开发
|
综合
|
单台5600 QPS(1.2k)
无法跨语言是硬伤
|
解决跨语言及性能的理想解决方案;
尚未开发
|
中庸之道,大数据量时性能下降较快
|
|
性能一般,弃用
|
性能过差,弃用
|
最终选择
|
Y
|
Y
|
Y
|
|
N
|
N
|
1.8 Java序列化
1.8.1 说明
· 序列化后的内容大小对远程调用影响非常大
· 向pojo增加一个方法不会导致序列化后的值变大
· 增加属性会导致对象序列化变大(String/Date:增10;int:增8;List:增27),但增长并不固定;空的对象序列化后是42,freedian对象是800多
· 一个对象的大小或属性的多少直接影响序列化后的值大小
· transient关键词,不序列化的东西
1.8.2 过程
◆将对象实例相关的类元数据输出。
◆递归地输出类的超类描述直到不再有超类。
◆类元数据完了以后,开始从最顶层的超类开始输出对象实例的实际数据值。
◆从上至下递归输出实例的数据
1.8.3 例子
public class Parent {
int parentVersion = 10;
}
class contain implements Serializable{
int containVersion = 11;
}
public class SerialTest extends Parent implements Serializable {
int version = 66;
contain con = new contain();
public int getVersion() {
return version;
}
}
· 协议、版本、新对象标识
· 对象类描述
· 属性version描述(类型、长度、名称)
· 属性con描述
· 父类(Parent )及父类属性描述
· 各个属性的值(parentVersion、version)
· contain类的描述、属性描述及值
3 代理机制
3.1 JAVA代理机制
3.1.1 reflect.Proxy
示例
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
/**
* reflect.Proxy代理Demo
*
*/
public class GenericProxyFactory {
/**
* 拦截处理类,负责保存对象并拦截处理
*/
private static class JavaBeanProxy<T> implements InvocationHandler {
/*
* 代理的对象,在构造函数中植入
*/
final T underlying;
public JavaBeanProxy(T underlying) {
this.underlying = underlying;
}
分享到:
相关推荐
服务消费者则需要通过@ServiceReference注解引用服务提供者提供的接口,Dubbo会自动从Nacos获取服务实例,从而实现远程调用。在消费者端,我们可以通过接口方法直接调用远程服务,就像调用本地方法一样便捷。 为了...
5. **调用服务方法**:一旦连接建立,客户端就可以通过Binder对象调用服务的方法。调用完成后,记得要调用`unbindService()`断开连接,以避免资源泄漏。 在提供的文件列表中,"easymorse"和"testserver"可能分别是...
在IT行业中,远程服务调用是一项关键的技术,它允许不同系统之间通过网络交换数据和执行操作,从而实现多个系统的交互。本示例着重讲解如何利用Java的HttpClient库来实现这一功能。HttpClient是Apache软件基金会的一...
而RMI是Java特有的远程调用技术,它同样使用Stub和Skeleton,使得客户端可以调用远程对象的方法,进行对象级的通信。 在分布式环境下,服务调用面临的关键问题包括动态更新、事务处理和安全性。动态更新要求模型能...
本文将深入探讨在FLEX环境中实现Model-View-Presenter(MVP)模式的应用,以及如何通过ColdFusion进行远程服务调用。MVP模式是一种设计模式,常用于用户界面的架构,旨在分离业务逻辑、用户界面和数据呈现,提高代码...
首先,我们需要定义一个服务接口,例如`HelloService`,包含一个或多个方法,这些方法将被远程调用。然后,我们需要实现这个接口并部署为一个Hessian服务。在服务器端,通过HessianServlet来暴露这个服务,客户端则...
Surging 是一款强大的分布式微服务框架,其核心特性在于提供了高性能的RPC(Remote Procedure Call)远程服务调用机制。在微服务架构中,服务间的通信是至关重要的,Surging 正是为了解决这一问题而设计。通过使用 ...
Spring Cloud Feign 实现远程调用服务传输文件的方法 在微服务架构中,服务之间的调用和文件传输是非常常见的场景。Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来...
surging 是一个分布式微服务框架,提供高性能RPC远程服务调用,采用Zookeeper作为surging服务的注册中心,集成了哈希,随机,轮询作为负载均衡的算法,RPC集成采用的是netty框架,采用异步传输
云手机管理平台,基于dubbo进行远程服务调用,并通过虚拟化技术kvm, xen, vmware等,建立androidx86操作系统,对虚拟机进行统计管理,批量增加和销毁模拟器
HttpInvokerServiceExporter会自动处理请求的序列化和反序列化,使得远程调用过程简化。 1. **服务提供者端配置**:在服务端,你需要创建一个实现了特定业务接口的bean,并使用HttpInvokerServiceExporter来暴露这...
本示例聚焦于一个具体的场景:使用C#客户端远程调用基于Spring框架的Java Web服务。以下将详细阐述涉及的技术点。 首先,Spring框架是Java领域的一个核心组件,尤其在企业级应用开发中广泛使用。它提供了一个全面的...
远程调用服务框架是软件开发中的一个重要组成部分,它允许不同系统、不同网络环境下的应用程序之间进行通信,实现功能的解耦合和分布式系统的构建。在Java世界中,Spring框架提供了强大的支持来实现这一目标。本篇...
- 服务端:提供被调用服务的程序,接收并处理客户端的请求。 - 通信协议:RPC框架负责将调用请求转化为网络数据包,通过网络发送到服务器,并将返回结果解析为调用者可理解的形式。 2. **RPC的工作流程**: - ...
在客户端,我们需要创建一个`THttpClient`实例,连接到服务器,然后使用`TestClient`类调用服务: ```php $transport = new THttpClient('http://localhost:9090'); $protocol = new TBinaryProtocol($transport); ...
"Android案例-远程调用支付宝.zip"这个压缩包文件,显然涉及到如何在Android应用中集成支付宝的远程调用服务,以便实现支付功能。下面我们将深入探讨这一主题。 首先,服务在Android中的使用场景通常包括音乐播放、...
服务发现客户端可以通过服务注册中心查找并获取服务提供者的地址信息,从而进行远程调用。 2. 序列化与反序列化 Kryo序列化使用Kryo库进行高效的序列化和反序列化,适用于高性能场景。 JSON序列化使用JSON格式...
这个“完整版远程服务支持库.rar”很可能包含了一系列用于实现远程服务调用、通信和数据交换的软件组件。下面我们将深入探讨远程服务支持库的相关知识点。 1. **远程过程调用(RPC)**:远程服务支持库的核心概念之...
1. 远程接口(Remote Interface):定义了可以被远程调用的方法,这些接口需要继承自`java.rmi.Remote`接口,并且可能抛出`java.rmi.RemoteException`。 2. 远程实现(Remote Implementation):实现了远程接口的...