posts - 167,  comments - 30,  trackbacks - 0
          RMI的全稱是遠(yuǎn)程方法調(diào)用,相信不少朋友都聽說過,基本的思路可以用一個(gè)經(jīng)典比方來解釋:A計(jì)算機(jī)想要計(jì)算一個(gè)兩個(gè)數(shù)的加法,但A自己做不了,于是叫另外一臺(tái)計(jì)算機(jī)B幫忙,B有計(jì)算加法的功能,A調(diào)用它就像調(diào)用這個(gè)功能是自己的一樣方便。這個(gè)就叫做遠(yuǎn)程方法調(diào)用了。

          遠(yuǎn)程方法調(diào)用是EJB實(shí)現(xiàn)的支柱,建立分布式應(yīng)用的核心思想。這個(gè)很好理解,再拿上面的計(jì)算加法例子,A只知道去call計(jì)算機(jī)B的方法,自己并沒有B的那些功能,所以A計(jì)算機(jī)端就無法看到B執(zhí)行這段功能的過程和代碼,因?yàn)榭炊伎床坏剑约葲]有機(jī)會(huì)竊取也沒有機(jī)會(huì)去改動(dòng)方法代碼。EJB正式基于這樣的思想來完成它的任務(wù)的。當(dāng)簡單的加法變成復(fù)雜的數(shù)據(jù)庫操作和電子商務(wù)交易應(yīng)用的時(shí)候,這樣的安全性和分布式應(yīng)用的便利性就表現(xiàn)出來優(yōu)勢了。

          好了,回到細(xì)節(jié)上,要如何實(shí)現(xiàn)遠(yuǎn)程方法調(diào)用呢?我希望大家學(xué)習(xí)任何技術(shù)的時(shí)候可以試著依賴自己的下意識(shí)判斷,只要你的想法是合理健壯的,那么很可能實(shí)際上它就是這么做的,畢竟真理都蘊(yùn)藏在平凡的生活細(xì)節(jié)中。這樣只要帶著一些薄弱的Java基礎(chǔ)來思考RMI,其實(shí)也可以想出個(gè)大概來。

          a) 需要有一個(gè)服務(wù)器角色,它擁有真正的功能代碼方法。例如B,它提供加法服務(wù)
          b) 如果想遠(yuǎn)程使用B的功能,需要知道B的IP地址
          c) 如果想遠(yuǎn)程使用B的功能,還需要知道B中那個(gè)特定服務(wù)的名字

          我們很自然可以想到這些,雖然不完善,但已經(jīng)很接近正確的做法了。實(shí)際上RMI要得以實(shí)現(xiàn)還得意于Java一個(gè)很重要的特性,就是Java反射機(jī)制。我們需要知道服務(wù)的名字,但又必須隱藏實(shí)現(xiàn)的代碼,如何去做呢?答案就是:接口!
          舉個(gè)例子:
          public interface Person(){
          public void sayHello();
          }

          Public class PersonImplA implements Person{
          public PersonImplA(){}

          public void sayHello(){ System.out.println(“Hello!”);}
          }

          Public class PersonImplB implements Person{
          public PersonImplB(){}

          public void sayHello(){ System.out.println(“Nice to meet you!”);}
          }

          客戶端:Person p = Naming.lookup(“PersonService”);
          p.sayHello();

          就這幾段代碼就包含了幾乎所有的實(shí)現(xiàn)技術(shù),大家相信么?客戶端請(qǐng)求一個(gè)say hello服務(wù),服務(wù)器運(yùn)行時(shí)接到這個(gè)請(qǐng)求,利用Java反射機(jī)制的Class.newInstance()返回一個(gè)對(duì)象,但客戶端不知道服務(wù)器返回的是 ImplA還是ImplB,它接受用的參數(shù)簽名是Person,它知道實(shí)現(xiàn)了Person接口的對(duì)象一定有sayHello()方法,這就意味著客戶端并不知道服務(wù)器真正如何去實(shí)現(xiàn)的,但它通過了解Person接口明確了它要用的服務(wù)方法名字叫做sayHello()。

          如此類推,服務(wù)器只需要暴露自己的接口出來供客戶端,所有客戶端就可以自己選擇需要的服務(wù)。這就像餐館只要拿出自己的菜單出來讓客戶選擇,就可以在后臺(tái)廚房一道道的按需做出來,它怎么做的通常是不讓客戶知道的!(祖?zhèn)鞑俗V吧,^_^)

          最后一點(diǎn)是我調(diào)用lookup,查找一個(gè)叫PersonService名字的對(duì)象,服務(wù)器只要看到這個(gè)名字,在自己的目錄(相當(dāng)于電話簿)中找到對(duì)應(yīng)的對(duì)象名字提供服務(wù)就可以了,這個(gè)目錄就叫做JNDI (Java命名與目錄接口),相信大家也聽過的。

          有興趣的朋友不妨自己做個(gè)RMI的應(yīng)用,很多前輩的博客中有簡單的例子。提示一下利用Jdk的bin目錄中rmi.exe和 rmiregistry.exe兩個(gè)命令就可以自己建起一個(gè)服務(wù)器,提供遠(yuǎn)程服務(wù)。因?yàn)槔雍苋菀渍遥揖筒蛔约号e例子了!
          posted on 2010-08-17 10:30 David1228 閱讀(248) 評(píng)論(0)  編輯  收藏 所屬分類: JAVA

          <2010年8月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章檔案

          新聞分類

          新聞檔案

          相冊(cè)

          收藏夾

          Java

          Linux知識(shí)相關(guān)

          Spring相關(guān)

          云計(jì)算/Linux/虛擬化技術(shù)/

          友情博客

          多線程并發(fā)編程

          開源技術(shù)

          持久層技術(shù)相關(guān)

          搜索

          •  

          積分與排名

          • 積分 - 359288
          • 排名 - 154

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 民乐县| 孝昌县| 万州区| 通海县| 宁化县| 华宁县| 福鼎市| 临清市| 云南省| 曲周县| 张家口市| 新乡市| 略阳县| 铜川市| 德钦县| 安陆市| 上蔡县| 乐平市| 读书| 乐业县| 荣成市| 行唐县| 弥渡县| 信丰县| 万全县| 荣昌县| 凉城县| 电白县| 台东县| 葫芦岛市| 班戈县| 鲜城| 宁德市| 万州区| 子洲县| 兴隆县| 大同市| 明溪县| 平阴县| 双城市| 兴城市|