溫馨提示×

溫馨提示×

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

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

怎么用java編寫一個(gè)rmi

發(fā)布時(shí)間:2021-11-20 11:46:15 來源:億速云 閱讀:108 作者:iii 欄目:編程語言

本篇內(nèi)容介紹了“怎么用java編寫一個(gè)rmi”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

RMI 指的是遠(yuǎn)程方法調(diào)用 (Remote Method Invocation)。它是一種機(jī)制,能夠讓在某個(gè) Java虛擬機(jī)上的對象調(diào)用另一個(gè) Java 虛擬機(jī)中的對象上的方法。可以用此方法調(diào)用的任何對象必須實(shí)現(xiàn)該遠(yuǎn)程接口。

調(diào)用這樣一個(gè)對象時(shí),其參數(shù)為 "marshalled" 并將其從本地虛擬機(jī)發(fā)送到遠(yuǎn)程虛擬機(jī)(該遠(yuǎn)程虛擬機(jī)的參數(shù)為 "unmarshalled")上。該方法終止時(shí),將編組來自遠(yuǎn)程機(jī)的結(jié)果并將結(jié)果發(fā)送到調(diào)用方的虛擬機(jī)。如果方法調(diào)用導(dǎo)致拋出異常,則該異常將指示給調(diào)用方。

提供遠(yuǎn)端訪問的時(shí)候,我們首先需要定義遠(yuǎn)端能夠訪問哪些東西,在Java中,定義這類接口需要實(shí)現(xiàn)Remote接口

public interface Business extends Remote{public String echo(String msg) throws RemoteException;}

定義完接口之后,這些功能是需要我們自己在Server端實(shí)現(xiàn)的,因此,聲明一個(gè)類實(shí)現(xiàn)我們提供接口。

public class BusinessImpl implements Business{@Overridepublic String echo(String msg) throws RemoteException {if("quit".equalsIgnoreCase(msg)) {System.out.println("Server will be shutdown");System.exit(0);}System.out.println("Message from client:"+msg);return "Server response:"+msg;}}

實(shí)現(xiàn)完這個(gè)方法之后,有一個(gè)問題是,怎么運(yùn)行,既然是遠(yuǎn)端訪問,肯定得有端口號,肯定得有實(shí)例,所以我們還需要注冊我們的代碼

public class Server {public static final String SERVER_REGISTER_NAME = "BusineeDemo";public static void main(String[] args) throws RemoteException {int port = 2016;Business business = new BusinessImpl();UnicastRemoteObject.exportObject(business,port);Registry registry = LocateRegistry.createRegistry(1099);registry.rebind(SERVER_REGISTER_NAME, business);}}

這里有兩個(gè)Java的類:UnicastRemoteObject和LocateRegistry

一個(gè)接口:Registry

Registry接口:對簡單的遠(yuǎn)端對象提供一個(gè)遠(yuǎn)端接口用于提供存儲和獲取遠(yuǎn)端對象的引用,而這些是通過任意的String類型的變量名稱獲取,bind,unbind,rebind方法是用于更改注冊的這些名稱,lookup和list方法是用于查詢當(dāng)前當(dāng)前已經(jīng)綁定的對象。

UnicastRemoteObject類:用于導(dǎo)出一個(gè)遠(yuǎn)端對象

LocateRegistry類:是一個(gè)用來獲得遠(yuǎn)端調(diào)用對象引用的輔助類程序,主要是在一個(gè)特定的IP上構(gòu)建一個(gè)遠(yuǎn)端對象來接受來自特定端口的回調(diào)。

簡單的服務(wù)端完成了,現(xiàn)在來看客戶端:

客戶端代碼就更加簡單,前面我們提到我們可以通過Registry的lookup方法來獲取當(dāng)前已經(jīng)綁定的服務(wù),所以很自然,我們首先要獲得這個(gè)Registry

public class Client {public static void main(String[] args) throws RemoteException, NotBoundException {// Registry registry = LocateRegistry.getRegistry("localhost");Registry registry = LocateRegistry.getRegistry("localhost", 1099);Business business = (Business) registry.lookup(Server.SERVER_REGISTER_NAME);System.out.println(business.echo("Hello Server"));}}

“怎么用java編寫一個(gè)rmi”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向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