色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

詳解Java 中 RMI 的使用

瀏覽:86日期:2022-08-13 08:46:24

詳解Java 中 RMI 的使用

RMI 介紹

RMI (Remote Method Invocation) 模型是一種分布式對象應(yīng)用,使用 RMI 技術(shù)可以使一個 JVM 中的對象,調(diào)用另一個 JVM 中的對象方法并獲取調(diào)用結(jié)果。這里的另一個 JVM 可以在同一臺計算機(jī)也可以是遠(yuǎn)程計算機(jī)。因此,RMI 意味著需要一個 Server 端和一個 Client 端。

Server 端通常會創(chuàng)建一個對象,并使之可以被遠(yuǎn)程訪問。

這個對象被稱為遠(yuǎn)程對象。Server 端需要注冊這個對象可以被 Client 遠(yuǎn)程訪問。

Client 端調(diào)用可以被遠(yuǎn)程訪問的對象上的方法,Client 端就可以和 Server 端進(jìn)行通信并相互傳遞信息。

說到這里,是不是發(fā)現(xiàn)使用 RMI 在構(gòu)建一個分布式應(yīng)用時十分方便,它和 RPC 一樣可以實(shí)現(xiàn)分布式應(yīng)用之間的互相通信,甚至和現(xiàn)在的微服務(wù)思想都十分類似。

RMI 工作原理

正所謂 “知其然知其所以然”,在開始編寫 RMI 代碼之前,有必要了解一下 RMI 的工作原理,RMI 中 Client 端是和 Server 端是如何通信的呢?

下圖的可以幫助我們理解RMI 的工作流程。

詳解Java 中 RMI 的使用

從圖中可以看到,Client 端有一個被稱 Stub 的東西,有時也會被成為存根,它是 RMI Client 的代理對象,Stub 的主要功能是請求遠(yuǎn)程方法時構(gòu)造一個信息塊,RMI 協(xié)議會把這個信息塊發(fā)送給 Server 端。

這個信息塊由幾個部分組成:

遠(yuǎn)程對象標(biāo)識符。 調(diào)用的方法描述。 編組后的參數(shù)值(RMI協(xié)議中使用的是對象序列化)。

既然 Client 端有一個 Stub 可以構(gòu)造信息塊發(fā)送給 Server 端,那么 Server 端必定會有一個接收這個信息快的對象,稱為 Skeleton 。

它主要的工作是:

解析信息快中的調(diào)用對象標(biāo)識符和方法描述,在 Server 端調(diào)用具體的對象方法。 取得調(diào)用的返回值或者異常值。 把返回值進(jìn)行編組,返回給客戶端 Stub.

到這里,一次從 Client 端對 Server 端的調(diào)用結(jié)果就可以獲取到了。

RMI 開發(fā)

通過上面的介紹,知道了 RMI 的概念以及 RMI 的工作原理,下面介紹 RMI 的開發(fā)流程。

這里會通過一個場景進(jìn)行演示,假設(shè) Client 端需要查詢用戶信息,而用戶信息存在于 Server 端,所以在 Server 端開放了 RMI 協(xié)議接口供客戶端調(diào)用查詢。

RMI Server

Server 端主要是構(gòu)建一個可以被傳輸?shù)念?User,一個可以被遠(yuǎn)程訪問的類 UserService,同時這個對象要注冊到 RMI 開放給客戶端使用。

1.定義服務(wù)器接口(需要繼承 Remote 類,方法需要拋出 RemoteException)。

package com.wdbyte.rmi.server;import java.rmi.Remote;import java.rmi.RemoteException;/** * RMI Server * * @author www.wdbyte.com * @date 2021/05/08 */public interface UserService extends Remote { /** * 查找用戶 * * @param userId * @return * @throws RemoteException */ User findUser(String userId) throws RemoteException;}

User 對象在步驟 3 中定義。

2.實(shí)現(xiàn)服務(wù)器接口(需要繼承 UnicastRemoteObject 類,實(shí)現(xiàn)定義的接口)。

package com.wdbyte.rmi.server;import java.rmi.RemoteException;import java.rmi.server.UnicastRemoteObject;/** * @author www.wdbyte.com * @date 2021/05/08 */public class UserServiceImpl extends UnicastRemoteObject implements UserService { protected UserServiceImpl() throws RemoteException { } @Override public User findUser(String userId) throws RemoteException {// 加載在查詢 if ('00001'.equals(userId)) { User user = new User(); user.setName('金庸'); user.setAge(100); user.setSkill('寫作'); return user;}throw new RemoteException('查無此人'); }}

3.定義傳輸?shù)膶ο?,傳輸?shù)膶ο笮枰獙?shí)現(xiàn)序列化(Serializable)接口。

需要傳輸?shù)念愐欢ㄒ獙?shí)現(xiàn)序列化接口,不然傳輸時會報錯。IDEA 中如何生成 serialVersionUID,在文章末尾也附上了簡單教程。

package com.wdbyte.rmi.server;import java.io.Serializable;/** * * @author www.wdbyte.com * @date 2021/05/08 */public class User implements Serializable { private static final long serialVersionUID = 6490921832856589236L; private String name; private Integer age; private String skill; public String getName() {return name; } public void setName(String name) {this.name = name; } public Integer getAge() {return age; } public void setAge(Integer age) {this.age = age; } public String getSkill() {return skill; } public void setSkill(String skill) {this.skill = skill; }@Override public String toString() {return 'User{' + 'name=’' + name + ’’’ + ', age=' + age + ', skill=’' + skill + ’’’ + ’}’; }}

4.注冊( rmiregistry)遠(yuǎn)程對象,并啟動服務(wù)端程序。

服務(wù)端綁定了 UserService 對象作為遠(yuǎn)程訪問的對象,啟動時端口設(shè)置為 1900。

package com.wdbyte.rmi.server;import java.rmi.Naming;import java.rmi.registry.LocateRegistry;/** * RMI Server 端 * * @author https://www.wdbyte.com * @date 2021/05/08 */public class RmiServer { public static void main(String[] args) {try { UserService userService = new UserServiceImpl(); LocateRegistry.createRegistry(1900); Naming.rebind('rmi://localhost:1900/user', userService); System.out.println('start server,port is 1900');} catch (Exception e) { e.printStackTrace();} }}RMI Client

相比 Server 端,Client 端就簡單的多。直接引入可遠(yuǎn)程訪問和需要傳輸?shù)念悾ㄟ^端口和 Server 端綁定的地址,就可以發(fā)起一次調(diào)用。

package com.wdbyte.rmi.client;import java.rmi.Naming;import com.wdbyte.rmi.server.User;import com.wdbyte.rmi.server.UserService;/** * @author https://www.wdbyte.com * @date 2021/05/08 */public class RmiClient { public static void main(String args[]) {User answer;String userId = '00001';try { // lookup method to find reference of remote object UserService access = (UserService)Naming.lookup('rmi://localhost:1900/user'); answer = access.findUser(userId); System.out.println('query:' + userId); System.out.println('result:' + answer);} catch (Exception ae) { System.out.println(ae);} }}RMI 測試

啟動 Server 端。

start server,port is 1900

啟動 Client 端。

query:00001result:User{name=’金庸’, age=100, skill=’寫作’}

如果 Client 端傳入不存在的 userId。

java.rmi.ServerException: RemoteException occurred in server thread; nested exception is: java.rmi.RemoteException: 查無此人serialVersionUID 的生成

IDEA 中生成 serialVersionUID,打開設(shè)置,如下圖所示勾選。

詳解Java 中 RMI 的使用

選中要生成 serialVersionUID 的類,按智能提示快捷鍵。

詳解Java 中 RMI 的使用

參考

[1] https://docs.oracle.com/javase/tutorial/rmi/overview.html

到此這篇關(guān)于詳解Java 中 RMI 的使用的文章就介紹到這了,更多相關(guān)java RMI使用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产在线一区二区三区欧美 | 亚洲欧美偷拍自拍 | 性盈盈影院在线观看 | 一区二区精品在线观看 | 欧美一级片手机在线观看 | 亚洲美女高清aⅴ视频免费 亚洲美女黄色片 | 亚洲欧美日韩国产专区一区 | 特色一级片 | 亚洲综合免费视频 | 亚洲视频一区二区在线观看 | 国产美女自拍视频 | 亚洲精品天堂自在久久77 | 久久不卡日韩美女 | 国产国语高清在线视频二区 | 国产精品19禁在线观看2021 | 九九国产在线视频 | 日日狠狠久久偷偷四色综合免费 | 欧美亚洲一区二区三区在线 | 久久伊人男人的天堂网站 | 亚洲高清一区二区三区四区 | 国产主播精品福利19禁vip | 美女视频网站永久免费观看软件 | 欧美另类在线视频 | 97国产成人精品免费视频 | 精品视频在线视频 | 久99频这里只精品23热 视频 | 男女性生活网站 | 国产在线观看一区二区三区 | 一本色道久久综合亚洲精品高清 | 久久精品亚洲乱码伦伦中文 | 日本免费一二区视频 | 久热草在线 | 97久久精品一区二区三区 | 67id人成国产在线 | 国产一级性生活 | 九九亚洲视频 | 欧美三级免费 | 国产精品一区在线免费观看 | 操操综合网 | 91免费国产高清观看 | 国产免费一区二区三区在线 |