明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

RMI一步一步來

[摘要]RMI,遠程方法調(diào)用(Remote Method Invocation)是Enterprise JavaBeans的支柱,是建立分布式Java應(yīng)用程序的方便途徑。RMI是非常容易使用的,但是它非常的強大。   RMI的基礎(chǔ)是接口,RMI構(gòu)架基于一個重要的原理:定義接口和定義接口的具體實現(xiàn)是分開的。...
RMI,遠程方法調(diào)用(Remote Method Invocation)是Enterprise JavaBeans的支柱,是建立分布式Java應(yīng)用程序的方便途徑。RMI是非常容易使用的,但是它非常的強大。
  RMI的基礎(chǔ)是接口,RMI構(gòu)架基于一個重要的原理:定義接口和定義接口的具體實現(xiàn)是分開的。下面我們通過具體的例子,建立一個簡單的遠程計算服務(wù)和使用它的客戶程序

  一個正常工作的RMI系統(tǒng)由下面幾個部分組成:
  遠程服務(wù)的接口定義
  遠程服務(wù)接口的具體實現(xiàn)
  樁(Stub)和框架(Skeleton)文件
  一個運行遠程服務(wù)的服務(wù)器
  一個RMI命名服務(wù),它允許客戶端去發(fā)現(xiàn)這個遠程服務(wù)
  類文件的提供者(一個HTTP或者FTP服務(wù)器)
  一個需要這個遠程服務(wù)的客戶端程序
  下面我們一步一步建立一個簡單的RMI系統(tǒng)。首先在你的機器里建立一個新的文件夾,以便放置我們創(chuàng)建的文件,為了簡單起見,我們只使用一個文件夾存放客戶端和服務(wù)端代碼,并且在同一個目錄下運行服務(wù)端和客戶端。

  如果所有的RMI文件都已經(jīng)設(shè)計好了,那么你需要下面的幾個步驟去生成你的系統(tǒng):

  1、 編寫并且編譯接口的Java代碼
  2、 編寫并且編譯接口實現(xiàn)的Java代碼
  3、 從接口實現(xiàn)類中生成樁(Stub)和框架(Skeleton)類文件
  4、 編寫遠程服務(wù)的主運行程序
  5、 編寫RMI的客戶端程序
  6、 安裝并且運行RMI系統(tǒng)

  1、 接口
  第一步就是建立和編譯服務(wù)接口的Java代碼。這個接口定義了所有的提供遠程服務(wù)的功能,下面是源程序:

  //Calculator.java
  //define the interface
  import java.rmi.Remote;

  public interface Calculator extends Remote
  {
   public long add(long a, long b)
   throws java.rmi.RemoteException;

   public long sub(long a, long b)
   throws java.rmi.RemoteException;

   public long mul(long a, long b)
   throws java.rmi.RemoteException;

   public long div(long a, long b)
   throws java.rmi.RemoteException;
  }
  注意,這個接口繼承自Remote,每一個定義的方法都必須拋出一個RemoteException異常對象。

  建立這個文件,把它存放在剛才的目錄下,并且編譯。

  >javac Calculator.java

  2、 接口的具體實現(xiàn)

  下一步,我們就要寫遠程服務(wù)的具體實現(xiàn),這是一個CalculatorImpl類文件:

  //CalculatorImpl.java
  //Implementation
  import java.rmi.server.UnicastRemoteObject

  public class CalculatorImpl extends UnicastRemoteObject implements Calculator
  {

   // 這個實現(xiàn)必須有一個顯式的構(gòu)造函數(shù),并且要拋出一個RemoteException異常
   public CalculatorImpl()
   throws java.rmi.RemoteException {
   super();
   }

   public long add(long a, long b)
   throws java.rmi.RemoteException {
   return a + b;
   }

   public long sub(long a, long b)
   throws java.rmi.RemoteException {
   return a - b;
   }

   public long mul(long a, long b)
   throws java.rmi.RemoteException {
   return a * b;
   }

   public long div(long a, long b)
   throws java.rmi.RemoteException {
   return a / b;
   }
  }
  同樣的,把這個文件保存在你的目錄里然后編譯他。

  這個實現(xiàn)類使用了UnicastRemoteObject去聯(lián)接RMI系統(tǒng)。在我們的例子中,我們是直接的從UnicastRemoteObject這個類上繼承的,事實上并不一定要這樣做,如果一個類不是從UnicastRmeoteObject上繼承,那必須使用它的exportObject()方法去聯(lián)接到RMI。

  如果一個類繼承自UnicastRemoteObject,那么它必須提供一個構(gòu)造函數(shù)并且聲明拋出一個RemoteException對象。當這個構(gòu)造函數(shù)調(diào)用了super(),它久激活UnicastRemoteObject中的代碼完成RMI的連接和遠程對象的初始化。

  3、 樁(Stubs)和框架(Skeletons)

  下一步就是要使用RMI編譯器rmic來生成樁和框架文件,這個編譯運行在遠程服務(wù)實現(xiàn)類文件上。

  >rmic CalculatorImpl

  在你的目錄下運行上面的命令,成功執(zhí)行完上面的命令你可以發(fā)現(xiàn)一個Calculator_stub.class文件,如果你是使用的Java2SDK,那么你還可以發(fā)現(xiàn)Calculator_Skel.class文件。