溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時間:2020-08-08 14:17:34 來源:ITPUB博客 閱讀:185 作者:BSDLite 欄目:編程語言
在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引入的分布式對象軟件包,它的出現(xiàn)簡化了在多臺機(jī)器上的Java應(yīng)用之間的通信。相比CORBA,RMI功能較弱且只能用于Java系統(tǒng)。

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

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

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

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

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


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

2.RMI客戶類(RemClient.java)

RMI客戶使用Naming.lookup在指定的遠(yuǎn)程主機(jī)上查找對象,若找到就把它轉(zhuǎn)換成本地接口Rem類型,然后像一個本地對象一樣使用它。與CORBA不同之處在于RMI客戶必須知道提供遠(yuǎn)程服務(wù)主機(jī)的URL,這個URL可以通過rmi://host/path或rmi://host:port/path來指定,如果省略端口號,就使用1099。Naming.lookup可能產(chǎn)生三個異常:RemoteException、NotBoundException、MalformedURLException,三個尋常都需要捕獲。RemoteException、Naming和NotBoundException在java.rmi.*中定義,MalformedURLException在java.net.*中定義。另外,客戶機(jī)將向遠(yuǎn)程對象傳遞串行化對象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ī)上查找對象,并把它轉(zhuǎn)化為本地接口Rem類型
Rem remObject=(Rem)Naming.lookup("rmi://" + host + "/Rem");
System.out.println(remObject.getMessage()); //調(diào)用遠(yuǎn)程對象的方法
} 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)程對象實(shí)現(xiàn)類(RemImpl.java)
這個類真正實(shí)現(xiàn)RMI客戶調(diào)用的遠(yuǎn)程對象,它必須從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客戶返回一個消息串 4.RMI服務(wù)器類(RemServer.java)該類創(chuàng)建遠(yuǎn)程對象實(shí)現(xiàn)RemImpl的一個實(shí)例,然后用一個特定的URL來注冊它,所謂注冊就是通過Naming.bind或Naming.rebind來將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)程對象實(shí)現(xiàn)的一個實(shí)例 Naming.rebind("rmi:///Rem", localObject); //將遠(yuǎn)程對象實(shí)例綁定到rmi:///Rem上 }catch(RemoteException re){System.out.println("RemoteException:"+re); }catch(MalformedURLException mfe) {System.out.println("MalformedURLException: "+mfe); }}}

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

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI