RMI應用部署
最近在看《JAVA網路程式設計精解》到第十章突然迷糊了,怎麼都看不懂怎麼部署的,特別是在伺服器與客戶程式分佈不同機器上的時候,java.rmi.server.codebase的時候,總是出現ClassNotFoundException。下面說說RMI應用程式的部署過程。
RMI應用由3部分組成,伺服器、客戶端和登錄檔程式,這三個程式部署由三種方式部
1.伺服器、客戶端和登錄檔程式在同一臺的機器上,一般實驗的時候可以使用,教材上都採用這種模式。
2.伺服器與登錄檔程式執行在一臺機器,而客戶端執行在另一臺機器上。下面講的就是這種方式
3.伺服器、登錄檔、客戶端程式執行於三個不同的機器,這時就需要設定java.rmi.server.codebase=path,來讓登錄檔程式能夠通過path找到遠端物件的介面類,並完成註冊。實際上jdk5以後,採用動態代理生成stub類,客戶端和(伺服器-登錄檔分離時),通過java.rmi.server.codebase=path指名stub類的地址
關於java.rmi.server.codebase具體可以參考官方文件https://docs.oracle.com/javase/6/docs/technotes/guides/rmi/hello/hello-world.html
對於第二種部署方式,可以參考:https://segmentfault.com/a/1190000004494341#articleHeader22這裡詳細說明了兩臺機器上的不熟方式:關於上面連結程裡有些不清楚的,我給出我的理解:
首先客戶與伺服器分離,分別建立java專案作為伺服器和客戶端
RMIClient
Client
RMMIServer:Hello
package com.cl.remote;
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface Hello extends Remote{
String sayHello() throws RemoteException;
}
RMMIServer:Server
package com.cl.remote;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;
public class Server implements Hello{
public Server() {
super();
}
@Override
public String sayHello() throws RemoteException {
// TODO Auto-generated method stub
return "Hello World";
}
public static void main(String[] args) {
System.setProperty("java.security.policy",Server.class.getResource("rmi.policy").toString());
if(System.getSecurityManager()==null){
System.setSecurityManager(new SecurityManager());
}
try {
Registry registry=LocateRegistry.createRegistry(1099);
Server obj=new Server();
Hello stub=(Hello) UnicastRemoteObject.exportObject(obj,1099);
registry.bind("Hello", stub);
System.out.println();
System.err.println("Server ready");
} catch (Exception e) {
e.printStackTrace();
}
}
}
RMIClient:Client
package com.cl.client;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import com.cl.remote.Hello;
public class Client {
public static void main(String[] args) {
//System.out.println(Client.class.getResource("rmi.policy").toString());
//file:/E:/myprograms/WorkPlaceForEclipse_Java_NetProgram/RMIApp/bin/com/cl/rmi_test2/rmi.policy
System.setProperty("java.security.policy",Client.class.getResource("rmi.policy").toString());
if(System.getSecurityManager()==null){
System.setSecurityManager(new SecurityManager());
}
String host = (args.length<1)?null:args[0];
String port=(args.length<2)?"1099":args[1];
try {
Registry registry=LocateRegistry.getRegistry(host,Integer.parseInt(port));
Hello stub=(Hello) registry.lookup("Hello");
String response=stub.sayHello();
System.out.println("response:" +response);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
RMIClient:Hello
package com.cl.remote;
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface Hello extends Remote{
String sayHello() throws RemoteException;
}
值得注意的是RMIClient和RMMIServer的Hello完全一樣(包名也一樣)具體客戶端的介面類參考https://blog.csdn.net/gaohuanjie/article/details/38338765
客戶端一定需要遠端的介面類檔案,因為需要在客戶端呼叫遠端類的遠端方法,如果沒有這個類編譯是過不去的。開始我以為《JAVA網路程式設計精解》裡提到的客戶端沒有服務端的類檔案,以為是客戶端可以沒有遠端介面類檔案,結果最後才發現作者提到的是
如果Hello包名在客戶端與服務端設定的不一樣,會導致客戶端Hello stub=(Hello) registry.lookup("Hello");轉型時出錯,因為返回的是com.cl.remote.Hello的存根類,而Client本地的Hello包名不是com.cl.remote話,是無法強轉的。
rmi.policy參考https://segmentfault.com/a/1190000004494341#articleHeader22
部署過程:
1.win10上執行伺服器程式:
因為在程式裡設定了java.security.policy,不用再使用java -Djava.security.policy設定,客戶端也一樣。
2.lunix下部署客戶端程式:
將RMIClient的bin目錄拷到lunix下,如圖:
隨後輸入:
其中192.168.56.1是win10主機的IP,1099是埠,可以發現lunix下輸出了:
於是部署執行完成。
歡迎大家與我討論RMI.
相關文章
- 輕鬆部署 Laravel 應用 | 《08. 手動部署 - 部署應用程式碼》Laravel
- Flask 應用如何部署Flask
- Kubernetes(二) 應用部署
- SQLCoder部署和應用SQL
- LNMP部署及應用LNMP
- Docker部署Angular應用DockerAngular
- 用 Ansible 部署無服務應用!
- 阿里canal部署和應用阿里
- Docker常用的應用部署Docker
- 使用dockerfile部署springboot應用DockerSpring Boot
- 使用 Docker 部署 Node 應用Docker
- golang: 線上上用nginx部署應用GolangNginx
- 用linuxdeployqt吧Qt應用部署到LinuxLinuxQT
- 如何使用 docker 部署前端應用Docker前端
- 如何快速部署容器化應用
- 007.OpenShift管理應用部署
- CentOS 部署 Laravel 應用 記錄CentOSLaravel
- 將Laravel應用部署到HerokuLaravel
- Docker容器化部署Python應用DockerPython
- waf 應用防火牆部署配置防火牆
- LangServe如何革新LLM應用部署?Gse
- Docker_Docker應用部署4Docker
- 容器化部署實踐之Django應用部署(二)Django
- RMI基礎
- 揭秘貨拉拉大模型應用平臺的應用部署大模型
- Docker中部署.NET CORE應用(控制檯應用程式篇)Docker
- 應用部署初探:微服務的3大部署模式微服務模式
- 【轉】Docker部署Tomcat及Web應用DockerTomcatWeb
- SAE 的極致應用部署效率
- 輕鬆部署 Laravel 應用 | 《開篇》Laravel
- Helm部署k8s應用K8S
- kubernetes部署第一個應用案例
- Java應用構建並部署ECSJava
- 部署Azure Spring Cloud微服務應用SpringCloud微服務
- 使用 CodeGalaxy Cli 快速部署 Hyperf 應用
- Azure Terraform(三)部署 Web 應用程式ORMWeb
- wildfly 21中應用程式的部署
- 使用Docker容器化部署實踐之Django應用部署(一)DockerDjango