在Java中實(shí)現(xiàn)遠(yuǎn)程方法調(diào)用(轉(zhuǎn))

在Java中實(shí)現(xiàn)遠(yuǎn)程方法調(diào)用(轉(zhuǎn))[@more@]一、Java中的遠(yuǎn)程方法調(diào)用

遠(yuǎn)程方法調(diào)用(Remote Method Invocation, RMI)是Java1.1引入的分布式對(duì)象軟件包,它的出現(xiàn)簡(jiǎn)化了在多臺(tái)機(jī)器上的Java應(yīng)用之間的通信。相比CORBA,RMI功能較弱且只能用于Java系統(tǒng)。

二、實(shí)現(xiàn)一個(gè)簡(jiǎn)單的RMI

要使用RMI,必須構(gòu)造四個(gè)主要的類:遠(yuǎn)程對(duì)象的本地接口、RMI客戶、遠(yuǎn)程對(duì)象實(shí)現(xiàn)和RMI服務(wù)器。RMI服務(wù)器生成遠(yuǎn)程對(duì)象實(shí)現(xiàn)的一個(gè)實(shí)例,并用一個(gè)特殊的URL注冊(cè)它,RMI客戶在遠(yuǎn)程服務(wù)器上查找對(duì)象,若找到就把它轉(zhuǎn)換成本地接口類型,然后像一個(gè)本地對(duì)象一樣使用它。下面是一個(gè)簡(jiǎn)單的RMI例子,遠(yuǎn)程對(duì)象只返回一個(gè)消息字符串。要使這個(gè)例子更有價(jià)值,我們需要做的就是完善遠(yuǎn)程對(duì)象實(shí)現(xiàn)類。

1.遠(yuǎn)程對(duì)象的本地接口類(Rem.java)

該類僅僅是一個(gè)接口,而不是實(shí)現(xiàn),RMI客戶機(jī)可以直接使用它,RMI服務(wù)器必須通過一個(gè)遠(yuǎn)程對(duì)象來(lái)實(shí)現(xiàn)它,并用某個(gè)URL注冊(cè)它的一個(gè)實(shí)例。

import java.rmi.*;
public interface Rem extends Remote { public String getMessage() throws RemoteException;}


本地接口(Rem)必須是公共的,否則客戶機(jī)在加載一個(gè)實(shí)現(xiàn)該接口的遠(yuǎn)程對(duì)象時(shí)就會(huì)出錯(cuò)。此外,它還必須從java.rmi.Remote繼承而來(lái),接口中的每一個(gè)方法都必須拋出遠(yuǎn)程異常java.rmi.RemoteException。

2.RMI客戶類(RemClient.java)

RMI客戶使用Naming.lookup在指定的遠(yuǎn)程主機(jī)上查找對(duì)象,若找到就把它轉(zhuǎn)換成本地接口Rem類型,然后像一個(gè)本地對(duì)象一樣使用它。與CORBA不同之處在于RMI客戶必須知道提供遠(yuǎn)程服務(wù)主機(jī)的URL,這個(gè)URL可以通過rmi://host/path或rmi://host:port/path來(lái)指定,如果省略端口號(hào),就使用1099。Naming.lookup可能產(chǎn)生三個(gè)異常:RemoteException、NotBoundException、MalformedURLException,三個(gè)尋常都需要捕獲。RemoteException、Naming和NotBoundException在java.rmi.*中定義,MalformedURLException在java.net.*中定義。另外,客戶機(jī)將向遠(yuǎn)程對(duì)象傳遞串行化對(duì)象Serializable,所以還應(yīng)在程序中輸入java.io.*。

import java.rmi.*;
import java.net.*;
import java.io.*;
public class RemClient {
public static void main(String[] args) {
try {
String host = (args.length > 0) ? args[0] : "localhost"; //從命令行讀取遠(yuǎn)程主機(jī)名
//通過URL在遠(yuǎn)程主機(jī)上查找對(duì)象,并把它轉(zhuǎn)化為本地接口Rem類型
Rem remObject=(Rem)Naming.lookup("rmi://" + host + "/Rem");
System.out.println(remObject.getMessage()); //調(diào)用遠(yuǎn)程對(duì)象的方法
} catch(RemoteException re) {System.out.println("RemoteException: " + re);
} catch(NotBoundException nbe) {System.out.println("NotBoundException: " + nbe);
} catch(MalformedURLException mfe){System.out.println("MalformedURLException:"+ mfe);
}}}
3.遠(yuǎn)程對(duì)象實(shí)現(xiàn)類(RemImpl.java)
這個(gè)類真正實(shí)現(xiàn)RMI客戶調(diào)用的遠(yuǎn)程對(duì)象,它必須從UnicastRemoteObject繼承,其構(gòu)造函數(shù)應(yīng)拋出RemoteException異常。
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;
public class RemImpl extends UnicastRemoteObject implements Rem {
public RemImpl() throws RemoteException {} //構(gòu)造函數(shù)拋出RemoteException異常
public String getMessage() throws RemoteException {
return("Here is a remote message."); }} //向RMI客戶返回一個(gè)消息串 4.RMI服務(wù)器類(RemServer.java)該類創(chuàng)建遠(yuǎn)程對(duì)象實(shí)現(xiàn)RemImpl的一個(gè)實(shí)例,然后用一個(gè)特定的URL來(lái)注冊(cè)它,所謂注冊(cè)就是通過Naming.bind或Naming.rebind來(lái)將RemImpl實(shí)例綁定到URL上。 import java.rmi.*; import java.net.*; public class RemServer { public static void main(String[] args) { try { RemImpl localObject = new RemImpl(); //生成遠(yuǎn)程對(duì)象實(shí)現(xiàn)的一個(gè)實(shí)例 Naming.rebind("rmi:///Rem", localObject); //將遠(yuǎn)程對(duì)象實(shí)例綁定到rmi:///Rem上 }catch(RemoteException re){System.out.println("RemoteException:"+re); }catch(MalformedURLException mfe) {System.out.println("MalformedURLException: "+mfe); }}}

三、編譯和運(yùn)行

編譯RMI客戶和服務(wù)器,這將自動(dòng)編譯遠(yuǎn)程對(duì)象的本地接口和遠(yuǎn)程對(duì)象實(shí)現(xiàn)
javac RemClient.java //自動(dòng)編譯遠(yuǎn)程對(duì)象的本地接口Rem.java
javac RemServer.java //自動(dòng)編譯遠(yuǎn)程對(duì)象實(shí)現(xiàn)RemImpl.java
生成客戶承接模塊和服務(wù)器框架
rmic RemImpl
這將構(gòu)造RemImpl_Stub.class和RemImpl_Skeleton.class。請(qǐng)將Rem.class、RemClient.class和RemImpl_Stub.class拷貝到RMI客戶機(jī),將Rem.class、RemImpl.class 、RemServer.class和RemImpl_Skeleton.class拷貝到RMI服務(wù)器。
啟動(dòng)RMI注冊(cè)
rmiregistry
//在服務(wù)器上執(zhí)行。不論有多少個(gè)遠(yuǎn)程對(duì)象,本操作只需做一次
運(yùn)行java RemServer.class
//啟動(dòng)RMI服務(wù)器(在服務(wù)器上執(zhí)行)
java RemClient.class
//啟動(dòng)RMI客戶,將輸出“Here is a remote message.”

分享題目:在Java中實(shí)現(xiàn)遠(yuǎn)程方法調(diào)用(轉(zhuǎn))
分享地址:http://bm7419.com/article4/isggoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)站排名、電子商務(wù)、網(wǎng)站內(nèi)鏈面包屑導(dǎo)航、虛擬主機(jī)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)