暂无图片
暂无图片
暂无图片
暂无图片
暂无图片
Java分布式处理技术.docx
11
9页
0次
2025-04-05
免费下载
Java
分布式处理技术
(RMI,JDNI)
1.1 RMI
的基本概念
1.1.1
什么是
RMI
RMI(Remote Method Invocation)
远程方法调用是一种计算机之间对象互相调用对
方函数,启动对方进程的一种机制,使用这种机制,某一台计算机上的对象在调用另外一
台计算机上的方法时,使用的程序语法规则和在本地机上对象间的方法调用的语法规则一
样。
1.1.2 RMI
的用途
1
、 分布式体系结构
我们为什么要使用分布式计算呢?
当我们想与多个用户或客户机共享一个中央资源(如一个数据库)时,就会使用分布式计算。
分布式计算用来利用多个系统的组合计算能力,以便比在单个系统上更有效或更快地解决问
题。
可以用多种方法配置多个计算机系统以共享处理,包括共享内存、共享磁盘或只是共享一
条公共通信通道。最新的技术允许物理上相隔很远的系统能够在处理计算问题时协同工作。
关于利用计算能力这一主题,因特网及伴随的通信协议
TCP/IP
的 出现已使无数的计算
机系统史无前例地连接起来。对一些应用程序来说,能够利用如此多的计算功能来解决问
题是令人满意的。甚至更吸引人的是,大多数计算机系 统都有充足的空闲时间,可以帮助
解决其它问题。将来,网格计算会利用分布式计算能力进行出售,这与电力行业出售电能
非常相似。
2
Java
分布式对象编程技术
RMI
Enterprise JavaBeans
的支柱,是建立分布式
Java
应用程序的方便途径。
只要按照
RMI
规则设计程序,可以不必再过问在
RMI
之下的网络细节了,如:
TCP
Socket
等等。任意两台计算机之间的通讯完全由
RMI
负责。调用远程计算机上的对象就
像本地对象一样方便。
1.1.3 RMI
应用程序分类
依据
RMI
应用程序各部分职责,可对应用程序进行如下分类:
服务器程序:服务器程序将创建多个远程对象,并使每个对象能够被引用。等待客户端调用
创建好的远程对象上的方法。
客户端程序:从服务端程序中得到一个或多个远程对象的引用。客户端能用此引用调用远程
对象上的方法。
对等计算程序:双方地位相等,互为对方的服务器和客户端。
1.2
创建
RMI
应用程序步骤
1
、 定义远程接口
Java
中,远程对象是实现远程接口的类的实例
,
远程接口声明每个要远程调用的方法。
在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通
过接口句柄发送消息即可。远程接口有如下特
远程接口必
public
属性。如不这样,非客户端与远程接口在同一个包内,则当
图装入实现远程接口的远程对象时,调用会得到错误
远程接口必须扩展接口
java.rmi.Remote
与应用程序本特定的例外之外,远程接口中的每个方法都必自己
throws
从句中声
java.rmi.RemoteException
。(或
RemoteException
类)。
代码范
1
package com.itjob;
import java.rmi.*;
public interface RmiSample extends Remote{
public int sum(int a,int b) throws RemoteException;
}
2
、 实现远程接口
远程对象实现类必须扩展远程对象
java.rmi.UnicastRemoteObject
类, 并实现定义
的远程接口。远程对象的实现类中包实现每个远程接口所指定的远程方法的代码。这个
可以附加的方法,客户只能使用远程接口中的方 法。因为客户是指向接口的一
个句不是它的个类。必为远程对象定义构函数,使只准备定义一个默认
函数,用它调用基类构函数。因为基 类构函数可能会
java.rmi.RemoteException
使无它用必须抛
java.rmi.RemoteException
例外。
代码范
2
package com.itjob.rmi;
import java.rmi.*;
import java.rmi.server.*;
import com.itjob.RmiSample ;
/**
远程接口实现类,继承
UnicastRemoteObject
并实现了
RmiSample
远程接口
*/
public class RmiSampleImpl extends UnicastRemoteObject implements
RmiSample{
//
覆盖默认函数并
RemoteException
public RmiSampleImpl() throws RemoteException{
super();
}
//
有远程实现方法必须抛
RemoteException
public int sum(int a,int b) throws RemoteException{
return a+b;
}
}
3
、 编服务器类
main
方法的类可以是实现类自身可以完全是另一个类。下通过
RmiSampleServer
来创建一个远程对象的实例,并通过
java.rmi.registry.LocateRegistry
类的
createRegistry
方法从定端口启动注册
务程序,可以通过
rmiregistry
令启动注册服务程序,注册服务程序的缺省运
端口为
1099
代码范
3
package com.itjob.rmi;
import java.rmi.*;
import java.rmi.registry.*;
public class RmiSampleServer{
public static void main(String[] args){
/*
创建和安装一个理器,令其支
RMI.
作为
Java
开发包的一部分
*
用于
RMI
一一个是
RMISecurityManager.
*
if(System.getSecurityManager() == null) {
System.setSecurityManager(new RMISecurityManager());
}
*/
try{
LocateRegistry.createRegistry(8808);
RmiSampleImpl server=new RmiSampleImpl();
Naming.rebind("//localhost:8808/SAMPLE-SERVER",server);
System.out.println ("
远程对象注册成功,
RMI
服务已启动,等待客户端调用
....");
}catch(java.net.MalformedURLException me){
System.out.println ("Malformed URL:"+me.toString());
}catch(RemoteException re){
System.out.println ("Remote exception:"+re.toString());
}catch(AlreadyBoundException abe){
System.out.println ("(AlreadyBound exception:"+ abe.toString());
}
}
}
代码范
3
中将将远程对象名字绑定到对远程对象的引用上:
LocateRegistry.createRegistry(8808);
定本
RMI
服务程序不使用默认端口
1099,
是使用自己指定的端口
8808
Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
将远程对象在服务器
注册定了将查找远程对象引用的
URL
URL
格式为
//host:port/name
。其中
host
注册表所在的主机(远程或本地),
port
注册表调用的端口
name
未经注
册表字符串
host
port
都是可选项。如果省略
host
,则主机默认
本地主机。如果省略
port
,则端口默认
1099
端口是
RMI
注册表
rmiregistry
使用的“著名”端口。
代码范
3
行结图所示
14.1
代码范
3
行结
4
、 编使用远程服务的客户机类
客户机类的主要功能有两个,一是通过
Naming.lookup
方法来构造注册服务程序
stu
b
程序实例,是调用服务器远程对象上的远程方法。
代码范
4
package com.itjob.rmi;
import java.rmi.*;
of 9
免费下载
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文档的来源(墨天轮),文档链接,文档作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。