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;
}
分享到:
相关推荐
电子商务之价格优化算法:梯度下降:机器学习在价格优化中的角色.docx
ToadforOracle与Oracle数据库版本兼容性教程.docx
360浏览器银河麒麟版 for X86 适配兆芯 / 海光 / intel / AMD CPU
使用React.js构建,提供多种主题可供选择,并且易于定制。该项目旨在帮助开发者和自由职业者创建自己的个性化投资组合。 主要功能点 多种主题可供选择,包括绿色、黑白、蓝色、红色、橙色、紫色、粉色和黄色 易于定制,可以在src/data文件夹中更新个人信息 包含主页、关于、简历、教育、技能、经验、项目、成就、服务、推荐信、博客和联系等多个部分 支持通过Google表单收集联系信息 提供SEO优化建议 支持多种部署方式,如Netlify、Firebase、Heroku和GitHub Pages 技术栈主要 React.js Material-UI Axios React-fast-marquee React-helmet React-icons React-reveal React-router-dom React-router-hash-link React-slick Slick-carousel Validator
中小型企业财务管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B
python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。
电子商务之价格优化算法:线性回归:价格优化策略实施.docx
内容概要:报告详细介绍了企业数字化转型的驱动因素、数字化转型方案分类及其应用场景,重点关注了云计算、超连接、数字孪生、人工智能、分布式账本、增材制造、人机接口、数据共享、工业物联网等关键技术。这些技术不仅支持了企业的运营效率提升和业务模式创新,也为实现更快、更开放、更高效的数字化转型提供了支撑。报告最后提出了企业实施数字化转型的六个步骤。 适合人群:企业高级管理人员、技术人员、咨询顾问,以及对工业数字化转型感兴趣的读者。 使用场景及目标:帮助企业制定和实施数字化转型策略,优化运营模式,提升业务效率,增强市场竞争力。同时,也可作为政府部门、研究机构和行业协会的参考文献。 其他说明:报告中提到的关键技术及其应用场景对企业数字化转型具有重要的指导意义,特别是对于那些希望通过数字化转型实现业务创新和升级的企业。
基于java的线上选课系统的设计与实现答辩PPT.pptx
安装前的准备 1、安装Python:确保你的计算机上已经安装了Python。你可以在命令行中输入python --version或python3 --version来检查是否已安装以及安装的版本。 个人建议:在anaconda中自建不同python版本的环境,方法如下(其他版本照葫芦画瓢): 比如创建python3.8环境,anaconda命令终端输入:conda create -n py38 python==3.8 2、安装pip:pip是Python的包管理工具,用于安装和管理Python包。你可以通过输入pip --version或pip3 --version来检查pip是否已安装。 安装WHL安装包 1、打开命令行(或打开anaconda命令行终端): 在Windows上,你可以搜索“cmd”或“命令提示符”并打开它。 在macOS或Linux上,你可以打开“终端”。 2、cd到whl文件所在目录安装: 使用cd命令导航到你下载的whl文件所在的文件夹。 终端输入:pip install xxx.whl安装即可(xxx.whl指的是csdn下载解压出来的whl) 3、等待安装完成: 命令行会显示安装进度,并在安装完成后返回提示符。 以上是简单安装介绍,小白也能会,简单好用,从此再也不怕下载安装超时问题。 使用过程遇到问题可以私信,我可以帮你解决! 收起
电子商务之价格优化算法:贝叶斯定价:贝叶斯网络在电子商务定价中的应用.docx
IMG_20241105_235746.jpg
基于java的毕业设计选题系统答辩PPT.pptx
专升本考试资料全套.7z
Trustwave DbProtect:数据库活动监控策略制定.docx
基于VB的程序实例,可供参考学习使用
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
该源码项目是一款基于Thinkphp5框架的Java插件设计,包含114个文件,其中Java源文件60个,PNG图片32个,XML配置文件7个,GIF图片7个,Git忽略文件1个,LICENSE文件1个,Markdown文件1个,Xmind文件1个,Idea项目文件1个,以及JAR文件1个。
数据库开发和管理最佳实践.pdf
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac