国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

RMI使用學習 小結

2024-09-05 00:21:25
字體:
來源:轉載
供稿:網友

四年前也是 Java 的 fans,也曾如火如荼的追求著 sun,追求著 java. 當然 RMI 肯定不會放過,但到目前為止還沒有在任何一個項目中用過,昨天聽了一個 java 老師的課,本來不去想聽,可想想我交了這么多 money,最后還是去。最叫人惡心的是他講的 RMI 一點實用價值都沒有,而且有的理論也不對。真的誤導人啊,學術理論和實踐是不能夠分離的,老師是這樣的,只能靠學生自己動手豐衣足食了。昨天晚上用了一點時間,從新研究了一下 RMI。舉個例子作為 RMI 學習的終結吧。
在寫這篇文章前也訪問了中國電信的高級工程師,根據他的介紹,RMI 有很多實現方式,而且現在他發現 RMI 在大規模分布式系統中,效率和性能不是很好。目前他帶領的團隊正在自行開發分布式應用。
隨著 web 2.0 時代的到來,SOA 開發思想的普及應用。分布式應用,將又一次走向高潮。
RMI 開發步驟大家都很清楚,這里舉個不用手動啟動 rmiRegistry, 也不要指定 codebase 和web server 的例子.底層 TCP/IP 細節我們不用去管他,你就把他看成像 SOAP、JNDI 等一樣的基于注冊服務的東西就行了 .

1. 遠程接口
import java.rmi.Remote;
import java.rmi.RemoteException;

public interface IRMI extends Remote {
public Object invoke(ITask task) throws RemoteException;
}
2.遠程接口實現

/**
* @author Jack.Wang
*
*/
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

public class IRMIImpl extends UnicastRemoteObject implements IRMI {

protected IRMIImpl() throws RemoteException {
super();
}

public Object invoke(ITask task) throws RemoteException {
System.out.println("注意:這是一個遠程調用");
Object obj = task.doWork();
System.out.println("調用ITask.doWork()方法的返回值:" + obj.toString());
// 客戶端調用,可以在服務器端播放需要的音樂
ProcessCaller.callMp3();
return obj;
}
}
3. 任務接口
/**
* @author Jack.Wang
*
*/
import java.io.Serializable;
public interface ITask extends Serializable {
public Object doWork();
}
4. 任務實現類
/**
* @author Jack.Wang
*
*/
public class TaskImpl implements ITask {

public Object doWork() {
System.out.println("當前程序處于遠程調用中");
return Thread.currentThread().getName() + " "
+ new Date(System.currentTimeMillis());
}
}
5.在java中調用windows程序
public class ProcessCaller {

public static void callMp3() {
Runtime ru = Runtime.getRuntime();
try {
// 調用播放器文件播放指定MP3
Process p1 = ru
.exec("C://Program Files//Windows Media Player//wmplayer D://Jack//Mp3//5.秋天不回來-王強.mp3");
} catch (Exception e) {

}
}
}
6. Server 端代碼
/**
* @author Jack.Wang
*
*/
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class RMIServer {

public static void registRemoteObject() throws Exception {
IRMIImpl impl = new IRMIImpl();
Naming.rebind("rmi://210.43.109.25:1111/mytask", impl);
System.out.println("bound success!");
}

private static Registry createRegistry() {
Registry registry = null;
int port = 1111;
try {
registry = LocateRegistry.getRegistry("210.43.109.25", port);
registry.list();
System.out.println("Register the exist server!");
} catch (final Exception e) {
try {
registry = LocateRegistry.createRegistry(port);
System.out.println("Register the exist server!port=" + port);
} catch (final Exception ee) {
ee.printStackTrace();
}
}
return registry;
}

/**
* 將對象注冊到rmi服務器上
*/
public static void bind() {
Registry registry = null;
registry = createRegistry();
try {
IRMIImpl impl = new IRMIImpl();
registry.rebind("mytask", impl);
System.out.println("mytask server start!");
} catch (Exception e) {
e.printStackTrace();
}
}

/**
* @param args
*/
public static void main(String[] args) {
try {
bind();
} catch (Exception e) {
e.printStackTrace();
}
}

}
7. Client 端代碼

/**
* @author Jack.Wang
*
*/
public class RMIClient {
public static void getRemoteObject() throws Exception {
IRMI obj = (IRMI) Naming.lookup("rmi://210.43.109.28:1111/mytask"); // 得到遠程發布的服務
TaskImpl task = new TaskImpl();
Object result = obj.invoke(task); // 調用遠程服務的方法
System.out.println(result.toString());
}

public static void main(String[] args) {
try {
getRemoteObject();
} catch (Exception e) {
e.printStackTrace();
}
}
}

小結:
建議把以上程序打包成 jar 文件,你可以在不同機子間測試。
RMI 就這么簡單,如果你覺得他不爽,就自己封裝 socket. 到時候要通知我哦,我也學習學習。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 德州市| 大关县| 涿鹿县| 珲春市| 上高县| 嘉荫县| 邹平县| 乌鲁木齐市| 阜城县| 盘锦市| 拉孜县| 洛浦县| 黔南| 南投市| 拜城县| 都江堰市| 武功县| 锦屏县| 揭阳市| 萍乡市| 互助| 江口县| 乌拉特中旗| 凤阳县| 玛多县| 邹城市| 叶城县| 磴口县| 堆龙德庆县| 德令哈市| 葫芦岛市| 鄂州市| 屏山县| 离岛区| 弥渡县| 江西省| 惠水县| 平远县| 陇川县| 永善县| 衡山县|