如果所有组件都在同一台计算机的同一个Java虚拟机的同一个堆空间上执行是最简单的,但实际中我们面对的往往不是如此单一的情况,如果用户端只是个能够执行Java的装置怎么办?如果为了安全性的理由只能让服务器上的程序存取数据库怎么办?
我们知道,大多数情况下,方法的调用都是发生在相同堆上的两个对象之间,如果要调用不同机器上的对象的方法呢?
通常,我们从某一台计算机上面取得另一台计算机上的信息是通过socket的输入/输出流,打开另一台计算机的socket连接,然后取得outputStream来写入数据.但如果要调用另一台计算机上,另一个Java虚拟机上面的对象的方法呢?我们当然可以自己定义和设计通信协议来调用,然后通过Socket把执行结果再传回去,并且还能够像是对本机的方法调用一样,也就是说想要调用远程的对象(像是别的堆上的),却又要像是一般的调用.这就是RMI带给我们的功能.
远程过程调用的设计
要创建出4种东西:服务器、客户端、服务器辅助设施和客户端辅助设施.
1.创建客户端和服务端应用程序,服务器应用程序时个远程服务,是个带有客户端会调用的方法的对象
2.创建客户端和服务器端的辅助设施(helper)他们会处理所有客户端和服务器的底层网络输入/输出细节,让客户端和程序好像在处理本地调用一样.
辅助设施的任务辅助设施是个在实际上执行通信的对象,他们会让客户端感觉上好像是在调用本机对象,客户端对象看起来像是在调用远程的方法,但实际上它只是在调用本地处理Socket和串流细节的代理.在服务器这端,服务器的辅助设施会通过socket连接来自客户端设施的要求,解析打包送来的信息,然后调用真正的服务,因此对服务对象来说此调用来自本地.服务的辅助设施取得返回值之后就把它包装然后送回去(通过socket的输出串流)给客户端的辅助设施.客户端的辅助设施会解开这些信息传输给客户端的对象 |
调用方法的过程
1.客户端对象对辅助设施对象调用doBigThing()
2.客户端辅助设施把调用信息打包通过网络送到服务器的辅助设施
3.服务端的辅助设施解开来自客户端辅助设施的信息,并以此调用真正的服务.
这个过程的描述图如下:
Java RMI提供客户端和服务器端的辅助设施对象
在Java中,RMI已经帮我们创建好客户端和服务器端的辅助设施,它也知道如何让客户端辅助设施看起来像是真正的服务,也就是说,RMI知道如何提供相同的方法给客户端调用.
此外,RMI有提供执行期所需全部的基础设施,包括服务的查询以及让客户端能够找到与取得客户端的辅助设施(真正的服务代理人).
使用RMI时,无需编写任何网络或输入/输出的程序,客户端对远程方法的调用就跟对同一个Java虚拟机上的方法调用是一样的.
一般调用和RMI调用有一点不同,虽然对客户端来说,此方法调用看起来像是本地的,但是客户端辅助设施会通过网络发出调用,此调用最终还是会涉及到socket和串流,一开始是本机调用,代理会把它转成远程的.中间的信息是如何从Java虚拟机送到Java虚拟机要看辅助设施对象所用的协议而定.
使用RMI时,必须要决定协议:JRMP或IIOP,JRMP是RMI原生的协议,它是为Java间的远程调用而设计的,另外一方面,IIOP是为了CORBA而产生的,它让我们能够调用Java对象或其它类型的远程方法,CORBA通常比RMI麻烦,因为若两端不全都是Java的话,就会产生一堆可怕的转译和交谈操作.
我们只关心Java对Java的操作,所以会使用相当简易的RMI.
在RMI中,客户端的辅助设施称为stub,而服务器端的辅助设施称为skeleton.
如何创建远程服务
1.创建Remote接口
远程的接口定义了客户端可以远程调用的方法,它是个作为服务的多态化类.stub和服务都会实现此接口
2.实现Remote接口
这个是真正执行的类,它实现出定义在该接口上的方法,它是客户端会调用的对象
3.用rmic产生stub和skeleton
客户端和服务器都有helper,我们无需创建这些类或产生这些类的源代码,这都会在执行JDK所附的rmic工具时自动地处理掉
4.启动RMI registry (rmiregistry)
rmiregistry就像电话薄,用户会从此处取得代理(客户端的stub/helper对象)
5.启动远程服务
必须让服务对象开始执行,实现服务的类会起始服务的实例并向RMI Registry注册,要有注册后才能对用户服务.
相关推荐
1. 资源管理:分布式操作系统具有统一的资源管理机制,能够跨节点分配和调度计算、存储等资源,提高整体系统的效率和利用率。这包括负载均衡、故障恢复、资源预留和动态调整等功能。 2. 通信机制:分布式系统中的...
远程方法调用(Java Remote Method Invocation, RMI)技术主要用于分布式计算结构中,解决程序、函数和数据的远程调用问题。该技术使得客户端和服务器能够实现互联互通,允许用户调用服务器上的JAVA程序中的任意类。...
Java在云计算领域也有广泛应用,如在Amazon Web Services(AWS)、Google Cloud Platform(GCP)等云平台上,开发者可以使用Java SDK来操作各种云服务,如存储、计算、数据库等。 七、游戏开发 虽然Java可能不是...
Java则是Hadoop等分布式计算框架的基础语言。 - **Python的Numpy和Scipy库**:提供了类似MATLAB的功能,但更加易于集成到Web服务中,并可在Hadoop环境下运行。 - **C++**:用于加速代码执行速度。 - **R**:适合...
UUID 唯一标识在 JAVA 中的生成和应用非常广泛,通过 UUID,可以使分布式系统中的所有元素都能有唯一的辨识资讯,而不需要透过中央控制端来做辨识资讯的指定。同时,UUID 也可以作为数据库数据表主键,保证每次生成...
Hadoop是一个用Java编写的开源分布式计算平台,针对大数据存储和处理的两个核心问题,提供了HDFS和MapReduce两大核心组件。HDFS是分布式文件存储系统,适合存储大量数据,具有高吞吐量、容错性和可伸缩性,能够支持...
- **云计算**:作为云服务的基础设施,支持云存储、计算等功能。 ### 结语 中间件作为软件产业的重要组成部分,其发展对于信息技术的进步具有重要意义。随着技术的不断进步和社会需求的变化,中间件也在不断地演进...
Hadoop是一个分布式计算框架,主要由HDFS(Hadoop Distributed File System)和MapReduce两部分组成。HDFS提供大规模数据存储,MapReduce则负责数据的并行处理。当面对海量数据时,Hadoop可以将任务拆分成多个子任务...
传统的编程语言如Java、Delphi等被互联网语言替代,如VB-Script、ECMAScript等,与互联网的联系更为紧密。开发人员开始关注如何在云计算环境下更有效地分配资源。开发工具的变化不仅仅在于技术层面,它还影响了开发...
以上知识点展示了云计算开发服务平台在构建过程中涉及的关键技术和组件,包括但不限于PaaS架构、开源框架的应用、分布式存储与计算、以及部署和安全配置等多个方面。通过了解和掌握这些知识点,可以更好地进行云计算...
除了Hadoop和Spark,Java还与其他大数据技术如Cassandra(分布式NoSQL数据库)、Hive(基于Hadoop的数据仓库工具)、Pig(用于Hadoop的高级数据分析工具)等紧密集成,提供了一整套完整的数据处理解决方案。...
利用WebMagic技术,可以开发出高效的Java爬虫,用于采集互联网上的招聘岗位信息。这些信息采集完毕后,会经过处理转化为CSV格式,以便于存储到HDFS中。HDFS支持超大文件的分布式存储,能够将数据存储在不同的服务器...
在IT行业,尤其是数据处理领域,Apache Spark是一个非常流行的分布式数据处理框架,而DataFrame作为Spark SQL中的一个核心数据结构,它提供了一种高效的分布式数据集合处理方式。但是,对于初学者或者不熟悉Spark ...
然而,SQL Server的开放性较差,因为它仅限于Windows操作系统,这可能影响其在大规模分布式环境中的稳定性和可伸缩性。在安全性上,SQL Server没有获得特定的安全认证,而且在多用户环境下性能可能下降。此外,SQL ...
另外,《iOS界面设计浅谈-blacksnail.rar》关注的是移动端用户体验设计。在iOS平台上,良好的界面设计对于提升用户满意度至关重要。文件可能涵盖了设计原则、人机交互、色彩和排版等方面,以及如何利用Apple的设计...
1.2 **淘宝网浅谈**: - **个人网站**:淘宝网早期以个人店铺形式存在,依赖简单的网页技术。 - **Java时代**:随着业务扩张,淘宝采用了Java技术构建复杂的服务体系,提升系统稳定性。 - **创造技术**:淘宝不断...
Java可视化集成开发环境的研究与实现.pdf Java调用VC_DLL实现串口GPS的访问.pdf LabVIEW_快速构建步进电机控制系统的利器.pdf LabVIEW下普通数据采集卡的驱动与调用.pdf LabVIEW下远程虚拟实验室的研究与实现....
Java可视化集成开发环境的研究与实现.pdf Java调用VC_DLL实现串口GPS的访问.pdf LabVIEW_快速构建步进电机控制系统的利器.pdf LabVIEW下普通数据采集卡的驱动与调用.pdf LabVIEW下远程虚拟实验室的研究与实现....
Java可视化集成开发环境的研究与实现.pdf Java调用VC_DLL实现串口GPS的访问.pdf LabVIEW_快速构建步进电机控制系统的利器.pdf LabVIEW下普通数据采集卡的驱动与调用.pdf LabVIEW下远程虚拟实验室的研究与实现....