溫馨提示×

溫馨提示×

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

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

Java RMI的使用方法

發(fā)布時(shí)間:2020-11-10 16:01:40 來源:億速云 閱讀:176 作者:lqh 欄目:編程語言

這篇文章運(yùn)用簡單易懂的例子給大家介紹Java RMI的使用方法,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

Java RMI詳解

概要:

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

Java RMI不是什么新技術(shù)(在Java1.1的時(shí)代都有了),但卻是是非常重要的底層技術(shù)。

大名鼎鼎的EJB都是建立在rmi基礎(chǔ)之上的,現(xiàn)在還有一些開源的遠(yuǎn)程調(diào)用組件,其底層技術(shù)也是rmi。 

在大力鼓吹Web Service、SOA的時(shí)代,是不是每個(gè)應(yīng)用都應(yīng)該選用笨拙的Web Service組件來實(shí)現(xiàn),通過對比測試后,RMI是最簡單的,在一些小的應(yīng)用中是最合適的。

下面通過一個(gè)簡單的例子來說明RMI的原理和應(yīng)用,下面這個(gè)例子是一個(gè)簡單HelloWorld,但已涵蓋RMI的核心應(yīng)用與開發(fā)模式。

 /** 
* Created by IntelliJ IDEA. 
* User: leizhimin 
* Date: 2008-8-7 21:50:02 
* 定義一個(gè)遠(yuǎn)程接口,必須繼承Remote接口,其中需要遠(yuǎn)程調(diào)用的方法必須拋出RemoteException異常 
*/ 
public interface IHello extends Remote { 

  /** 
   * 簡單的返回“Hello World!"字樣 
   * @return 返回“Hello World!"字樣 
   * @throws java.rmi.RemoteException 
   */ 
  public String helloWorld() throws RemoteException; 

  /** 
   * 一個(gè)簡單的業(yè)務(wù)方法,根據(jù)傳入的人名返回相應(yīng)的問候語 
   * @param someBodyName 人名 
   * @return 返回相應(yīng)的問候語 
   * @throws java.rmi.RemoteException 
   */ 
  public String sayHelloToSomeBody(String someBodyName) throws RemoteException; 
} 

/** 
* Created by IntelliJ IDEA. 
* User: leizhimin 
* Date: 2008-8-7 21:56:47 
* 遠(yuǎn)程的接口的實(shí)現(xiàn) 
*/ 
public class HelloImpl extends UnicastRemoteObject implements IHello { 
  /** 
   * 因?yàn)閁nicastRemoteObject的構(gòu)造方法拋出了RemoteException異常,因此這里默認(rèn)的構(gòu)造方法必須寫,必須聲明拋出RemoteException異常 
   * 
   * @throws RemoteException 
   */ 
  public HelloImpl() throws RemoteException { 
  } 

  /** 
   * 簡單的返回“Hello World!"字樣 
   * 
   * @return 返回“Hello World!"字樣 
   * @throws java.rmi.RemoteException 
   */ 
  public String helloWorld() throws RemoteException { 
    return "Hello World!"; 
  } 

  /** 
   * 一個(gè)簡單的業(yè)務(wù)方法,根據(jù)傳入的人名返回相應(yīng)的問候語 
   * 
   * @param someBodyName 人名 
   * @return 返回相應(yīng)的問候語 
   * @throws java.rmi.RemoteException 
   */ 
  public String sayHelloToSomeBody(String someBodyName) throws RemoteException { 
    return "你好," + someBodyName + "!"; 
  } 
}
/** 
* Created by IntelliJ IDEA. 
* User: leizhimin 
* Date: 2008-8-7 22:03:35 
* 創(chuàng)建RMI注冊表,啟動(dòng)RMI服務(wù),并將遠(yuǎn)程對象注冊到RMI注冊表中。 
*/ 
public class HelloServer { 
  public static void main(String args[]) { 

    try { 
      //創(chuàng)建一個(gè)遠(yuǎn)程對象 
      IHello rhello = new HelloImpl(); 
      //本地主機(jī)上的遠(yuǎn)程對象注冊表Registry的實(shí)例,并指定端口為8888,這一步必不可少(Java默認(rèn)端口是1099),必不可缺的一步,缺少注冊表創(chuàng)建,則無法綁定對象到遠(yuǎn)程注冊表上 
      LocateRegistry.createRegistry(8888); 

      //把遠(yuǎn)程對象注冊到RMI注冊服務(wù)器上,并命名為RHello 
      //綁定的URL標(biāo)準(zhǔn)格式為:rmi://host:port/name(其中協(xié)議名可以省略,下面兩種寫法都是正確的) 
      Naming.bind("rmi://localhost:8888/RHello",rhello); 
//      Naming.bind("//localhost:8888/RHello",rhello); 

      System.out.println(">>>>>INFO:遠(yuǎn)程IHello對象綁定成功!"); 
    } catch (RemoteException e) { 
      System.out.println("創(chuàng)建遠(yuǎn)程對象發(fā)生異常!"); 
      e.printStackTrace(); 
    } catch (AlreadyBoundException e) { 
      System.out.println("發(fā)生重復(fù)綁定對象異常!"); 
      e.printStackTrace(); 
    } catch (MalformedURLException e) { 
      System.out.println("發(fā)生URL畸形異常!"); 
      e.printStackTrace(); 
    } 
  } 
}
 /** 
* Created by IntelliJ IDEA. 
* User: leizhimin 
* Date: 2008-8-7 22:21:07 
* 客戶端測試,在客戶端調(diào)用遠(yuǎn)程對象上的遠(yuǎn)程方法,并返回結(jié)果。 
*/ 
public class HelloClient { 
  public static void main(String args[]){ 
    try { 
      //在RMI服務(wù)注冊表中查找名稱為RHello的對象,并調(diào)用其上的方法 
      IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello"); 
      System.out.println(rhello.helloWorld()); 
      System.out.println(rhello.sayHelloToSomeBody("熔巖")); 
    } catch (NotBoundException e) { 
      e.printStackTrace(); 
    } catch (MalformedURLException e) { 
      e.printStackTrace(); 
    } catch (RemoteException e) { 
      e.printStackTrace();  
    } 
  } 
}

關(guān)于Java RMI的使用方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向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