青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

P2P 應用程序框架

(來源:http://www-900.ibm.com/developerWorks/)

內(nèi)容:
安裝與執(zhí)行
配置文件
代碼
結束語
參考資料
關于作者
對本文的評價
深入細節(jié)

Todd Sundsted (todd-p2p@etcee.com)
首席設計師,PointFire, Inc.
2001 年 5 月

理解 P2P 計算技術方面的最好方法是仔細觀察一個實際的 P2P 應用程序。這個月,Todd Sundsted 將帶您體驗這樣一個應用程序。他描述了如何安裝、配置這個應用程序,以及它是如何工作的。

在 P2P 計算領域方面,我們只寫了一篇文章,現(xiàn)在已經(jīng)是轉變的時候了。根據(jù) 的讀者反饋意見,我認識到:讀者對于使用和理解 P2P 應用程序的興趣遠比我預想的大。最初,我只把這個應用程序看成是這樣一種方便的資源,可以從中提取示例,以闡明文章中所陳述的觀點。結果表明,某些讀者希望得到更詳細的信息,因此,我將在這個月提供這方面的信息。

這個月,我將不在高層次領域(高達 1000 英尺)繼續(xù)討論,也不解決安全性問題,相反,我將在低層次領域(50 英尺)討論應用程序框架。

我真誠地希望這個轉變將比現(xiàn)實生活中經(jīng)常遇到的轉變更令人愉快。

安裝與執(zhí)行
讓我們從安裝的具體細節(jié)開始。我略微更改了啟動 P2P 應用程序的過程,因為在上個月,一些讀者在啟動應用程序時遇到了問題。

在可以運行 P2P 應用程序之前,必須下載兩個 jar 文件 -- p2p.jar 和 spp.jar -- 以及配置文件 app.properties(請參閱參考資料)。p2p.jar 文件包含 P2P 應用程序自身的類文件。spp.jar 文件包含 P2P 應用程序所使用的消息傳遞庫的類文件。

下載這些文件之后,將這兩個 jar 文件和包含配置文件的目錄添加到類路徑中。

如果您正在運行 Windows,并且已經(jīng)將這兩個 jar 文件和配置文件下載到 c:\p2p 目錄,則可以如下設置類路徑:


  set CLASSPATH=c:\p2p\p2p.jar;c:\p2p\spp.jar;c:\p2p

如果您正在運行 Linux、Solaris 或某個合適的 UNIX 變體,并且已經(jīng)將這兩個 jar 文件和配置文件下載到 /home/foo/p2p 目錄,可如下設置類路徑:


  export CLASSPATH=/home/foo/p2p/p2p.jar:/home/foo/p2p/spp.jar:/home/foo/p2p

(以上命令假設您正在運行 BASH 來作為命令 shell)。我將如何在其它流行的 shell(如 CSH)中設置環(huán)境變量的問題留給您自己去考慮。

一旦設置了類路徑,就可以用以下命令啟動應用程序:


  java com.etcee.app.ki.Main

P2P 應用程序將顯示一個別致的信息性標志和一個命令提示來歡迎您。

最后再說一遍:我的 P2P 應用程序一定需要 Java 2 平臺。

配置文件
前幾步將啟動并運行 P2P 應用程序,但是,在能夠很好地使用它之前,必須編輯配置文件。配置文件定義 P2P 應用程序使用的端口、控制的資源以及識別的伙伴。清單 1 演示了每一個定義。

清單 1. 示例配置文件


  com.etcee.app.ki.port=7777
  com.etcee.app.ki.resource.0.name=share
  com.etcee.app.ki.resource.0.class=com.etcee.app.ki.resource.file.FileResource
  com.etcee.app.ki.resource.0.arg0=/home/foo/share
  com.etcee.app.ki.resource.1.name=tmp
  com.etcee.app.ki.resource.1.class=com.etcee.app.ki.resource.file.FileResource
  com.etcee.app.ki.resource.1.arg0=/tmp
  com.etcee.app.ki.peer.0=bass:7777
  com.etcee.app.ki.peer.1=salmon:7777
  com.etcee.app.ki.peer.2=perch:7777
  com.etcee.app.ki.peer.3=guppy:7777

第一部分由一行組成,它定義了 P2P 應用程序用來接收其它伙伴連接請求的端口。最好不要改變這行。

第二部分定義 P2P 應用程序管理的資源。您可能需要編輯這部分。清單 1 定義了兩個資源:sharetmp。從應用程序的觀點來看,資源只是實現(xiàn) Resource 接口的類的實例,我們將馬上講到這點。資源定義一般具有以下基本形式:

清單 2. 資源定義


  com.etcee.app.ki.resource.0.name=<name>
  com.etcee.app.ki.resource.0.class=<implementation class>
  com.etcee.app.ki.resource.0.arg0=<initialization argument>
  com.etcee.app.ki.resource.0.arg1=<initialization argument>
     .
     .

name 是給予資源的名稱,它用來生成人們可讀的輸出。class 是 Java 類的名稱,可以將其初始化以創(chuàng)建資源。P2P 應用程序在運行期間動態(tài)裝入這個類并將其初始化。在其初始化期間,argN 自變量被傳遞到新初始化的資源。例如,FileResource 類使用這些自變量定義目錄來為文件提供服務。您需要編輯目錄自變量以指向您機器上的某個目錄。

第三部分定義 P2P 應用程序識別的伙伴。每一行都包含伙伴的名稱(或 IP 地址)和伙伴的端口。用這種方式定義伙伴顯然不是可伸縮的解決方案。在以后的文章中,我們將看一種更好的解決方案。

代碼
除了對等通信采用的 SPP(簡單點到點)包之外,P2P 應用程序不包含很多類。首先,我們先仔細查看最重要的類,最后再看一下 SPP 通信包。

資源
P2P 應用程序的主要組件是資源。事實上,P2P 應用程序只是允許和控制對已發(fā)布資源的遠程訪問。資源可以是任何可尋址的事物 -- 文件系統(tǒng)、電話簿、數(shù)據(jù)庫和目錄。每個資源都管理零個或多個適當類型的項(文件系統(tǒng)資源管理文件,電話簿資源管理電話號碼)。

為演示如何實現(xiàn)資源,我創(chuàng)建了一個簡單的文件系統(tǒng)資源類 FileResource,如清單 3 所示。這個文件系統(tǒng)資源管理零個或多個文件。

清單 3. Resource 接口


  public
  interface Resource
  {
    // The initialize() method requires a TTDFactory instance
    // (which the factory uses to create the TTDItem instances
    // it returns from the select() method in response to a
    // query) and a String array (which contains the arguments
    // from the configuration file).
    public
    void
    initialize(TTDFactory ttdfactory, String [] arstring)
    throws ResourceException;
    // The select() method requires a String instance that
    // defines the selection criteria.  It returns an array
    // of TTDItems, one for each entry that matches the
    // selection criteria.
    public
    TTDItem []
    select(String stringSelector)
    throws ResourceException;
  }

Resource 接口定義資源的結構和行為。該接口還定義允許在資源上執(zhí)行的操作。目前的操作列表包括 select。以后的實現(xiàn)還將包括 insertdelete

select() 方法將一個定義選擇標準的字符串作為參數(shù)。該方法返回有關所有與選擇標準匹配的資源項的信息。按照當前 P2P 應用程序中的文件系統(tǒng)資源所實現(xiàn)的方式,選擇字符串既可以直接命名一項,也可以包含通配符 "*",當直接命名一項時,資源將返回該項本身及其相關元數(shù)據(jù);當包含通配符時,資源將只返回它所管理的所有項的元數(shù)據(jù)。還可以使用更復雜的查詢語言,但這不在本文討論范圍之內(nèi)。

Shell
Shell 類只是一個允許用戶瀏覽本地和遠程資源的非常簡單的命令行用戶接口。它使用 PeerReferenceResourceReferenceItemReference 類向其它伙伴發(fā)送請求,但它本身只分析用戶輸入。

為了從請求伙伴的角度更好地理解通信的工作原理,讓我們看一下清單 4 中顯示的 PeerReference 類的一部分。

因為我在上個月詳細描述了通過 shell 進行的用戶交互,所以不再這里重述。在第一次啟動 P2P 應用程序之前,請停一下并使自己重新熟悉它的操作。

通信
P2P 所做的全部就是伙伴間的通信。那些對原始得令人難以置信的 Napster 協(xié)議熟悉的讀者應該理解我為什么選擇高級一些的協(xié)議。我在這里只略微提及 SPP。在以后有關 P2P 通信的文章中,我將詳細描述它。

SPP 將消息建模成一個幀序列,如圖 1 所示。

圖 1. 消息
建模成幀序列的消息

消息中的每一幀都有一個類型(由 MIME 類型指明)和一個主體。幀中的頭是可選的,它用來描述主體中的數(shù)據(jù)。

構成完整而正確的消息的序列中的幀類型取決于應用程序。一般來講,一條消息由一個控制幀和其后零個或多個數(shù)據(jù)幀組成。數(shù)據(jù)幀包含控制幀所引用的數(shù)據(jù)。我們的 P2P 應用程序就采用這種模式。

消息出現(xiàn)在請求/響應對中。一個伙伴向另一個伙伴發(fā)送請求。那個伙伴再將響應發(fā)回給第一個伙伴。

請求消息中的控制幀是命令幀。它包含命令和為該命令提供的所有參數(shù)。如果有任何其它幀存在,則這些幀包含命令幀所需的信息。

響應消息中的控制幀是狀態(tài)幀。它包含狀態(tài)(正確或錯誤)。如果有任何其它幀存在,則這些幀包含狀態(tài)幀所引用的信息。如果向文件系統(tǒng)資源發(fā)出請求,則該信息將包含所選文件的內(nèi)容。

多幀消息模式的優(yōu)點在于:它允許在通信應用程序之間交換內(nèi)容豐富的消息。SPP 在很多方面都類似于 BXXP(請參閱參考資料)。

結束語
完全理解了框架之后,我們就可以在下個月繼續(xù)討論 P2P 安全性了。我們還將在 P2P 應用程序中集成安全性支持。

參考資料

關于作者
自從方便的臺式機出現(xiàn)以來,Todd Sundsted 就一直在編寫程序。盡管最初對用 C++ 構建分布式應用程序感興趣,但是,當 Java 成為同類語言中明顯的選擇時,Todd 轉到了 Java 編程語言。除了寫文章之外,Todd 還是 PointFire, Inc. 的創(chuàng)始人之一和首席設計師。可以通過
todd-p2p@etcee.com 與 Todd 聯(lián)系。

posted on 2006-07-31 11:21 楊粼波 閱讀(1257) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区成人精品| 欧美日韩福利在线观看| 国产精品美女久久久久久2018| 亚洲精品在线视频观看| 亚洲欧洲三级| 欧美日韩日本国产亚洲在线| 亚洲欧美另类综合偷拍| 午夜一区二区三区在线观看| 亚洲大片在线观看| 亚洲免费高清| 国产美女精品在线| 欧美a级理论片| 亚洲高清视频在线观看| 亚洲黄一区二区三区| 欧美日韩亚洲天堂| 欧美一区二区三区视频免费播放| 欧美一区二区观看视频| 亚洲美女视频在线免费观看| 亚洲私人影院| 亚洲国产成人久久综合| 亚洲一区二区三区在线看| 在线观看成人一级片| 一二三区精品福利视频| 亚洲第一网站免费视频| 一本色道久久88亚洲综合88| 好吊一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美成黄导航| 欧美在线高清| 欧美人与性动交a欧美精品| 久久国产精品72免费观看| 欧美激情视频一区二区三区免费| 欧美伊人久久| 欧美日韩专区在线| 欧美激情精品久久久久久久变态| 国产精品久久久久一区二区三区共 | 久久激情综合网| 欧美女同在线视频| 免费在线看一区| 国产精品免费视频观看| 91久久亚洲| 有码中文亚洲精品| 性欧美暴力猛交另类hd| 亚洲一二三四久久| 欧美成人免费网站| 久久综合五月| 国产一区亚洲一区| 亚洲永久精品大片| 亚洲综合日韩在线| 欧美日韩一区二区在线视频| 欧美激情视频一区二区三区免费| 国产婷婷精品| 亚洲欧美日韩国产成人| 亚洲欧美www| 欧美视频在线观看视频极品| 亚洲国产小视频| 亚洲国产日韩一区| 老司机午夜精品视频| 久久综合亚州| 亚洲电影免费在线| 免费的成人av| 亚洲国产精品久久91精品| 91久久国产综合久久| 欧美bbbxxxxx| 亚洲精品久久视频| 中日韩在线视频| 亚洲一区在线播放| 欧美精品18| 日韩亚洲综合在线| 亚洲夜间福利| 国产精品久久久久77777| 在线亚洲电影| 欧美在线视频免费观看| 国产偷自视频区视频一区二区| 亚洲一级特黄| 久久精品av麻豆的观看方式 | 欧美xart系列在线观看| 亚洲电影观看| 亚洲午夜黄色| 国产精品自拍小视频| 久久久精品国产免费观看同学| 免费观看成人www动漫视频| 狠狠狠色丁香婷婷综合久久五月| 久久久亚洲国产美女国产盗摄| 亚洲大胆在线| 亚洲综合第一| 在线观看91精品国产入口| 欧美成人精品| 亚洲女同性videos| 欧美黄色影院| 亚洲欧美日韩综合一区| 黑人一区二区| 欧美日韩在线观看一区二区| 午夜久久资源| 亚洲国产精品高清久久久| 亚洲女同在线| 亚洲欧洲另类国产综合| 国产精品视频网| 欧美成人激情在线| 欧美一区二区三区四区视频| 欧美激情一区二区久久久| 亚洲欧美成人在线| 亚洲国产精品成人一区二区| 欧美色图五月天| 久久综合九色九九| 亚洲尤物在线视频观看| 亚洲成色www8888| 羞羞答答国产精品www一本| 亚洲国产精品综合| 国产美女精品人人做人人爽| 欧美福利视频一区| 久久久91精品国产| 亚洲嫩草精品久久| 亚洲精品自在久久| 欧美国产三级| 久久天堂精品| 先锋亚洲精品| 亚洲午夜成aⅴ人片| 亚洲国产小视频在线观看| 国产一区二区三区直播精品电影 | 久久精品国产亚洲a| 亚洲视屏在线播放| 亚洲日韩成人| 欧美激情视频一区二区三区免费| 欧美在线三级| 午夜精彩国产免费不卡不顿大片| 亚洲精品久久久久久一区二区 | 国产精品国产三级国产普通话蜜臀 | 亚洲电影成人| 欧美国产综合视频| 久久亚洲综合网| 久久久久久久一区二区三区| 亚洲欧美综合一区| 亚洲一区免费视频| 日韩视频免费观看| 亚洲国产欧美日韩| 欧美成人精品不卡视频在线观看| 久久国产乱子精品免费女| 亚洲欧美一区二区三区在线| 亚洲视屏一区| 亚洲欧美日韩国产成人精品影院| 亚洲一区二区精品在线| 亚洲视频一二三| 亚洲图片欧洲图片av| 亚洲一区二区3| 亚洲一区二区动漫| 午夜欧美大片免费观看| 欧美一区二区三区在线观看| 久久国产手机看片| 久久在线免费| 欧美激情亚洲综合一区| 亚洲精品黄色| 亚洲一二区在线| 欧美中文日韩| 久久免费黄色| 欧美精品成人| 国产精品系列在线| 国产一区二区视频在线观看| 在线观看欧美黄色| 亚洲免费成人av电影| 亚洲在线视频| 久久精品一区二区三区中文字幕| 久久亚洲一区二区三区四区| 欧美成人综合网站| 一区二区三区www| 篠田优中文在线播放第一区| 久久人人爽国产| 欧美日韩另类丝袜其他| 国产日韩欧美制服另类| 激情自拍一区| 亚洲视频在线观看网站| 久久久高清一区二区三区| 欧美激情四色| 亚洲欧美日韩一区在线| 看片网站欧美日韩| 欧美性大战久久久久| 国产在线乱码一区二区三区| 亚洲精品国产精品国自产观看| 亚洲欧美日韩天堂| 欧美va天堂在线| 亚洲一区影院| 欧美精品久久久久久久免费观看| 国产欧美一区二区精品忘忧草| 亚洲高清影视| 欧美主播一区二区三区| 亚洲国产三级| 久久久久成人精品| 国产精品男人爽免费视频1| 亚洲国产高清一区二区三区| 欧美一区二区三区久久精品茉莉花 | 韩国一区二区三区美女美女秀| 亚洲精品视频在线播放| 久久精品国产亚洲精品| 亚洲美女淫视频| 美女视频黄免费的久久| 国产欧美一区二区精品性色 | 国产视频欧美视频| 亚洲视频免费在线| 亚洲福利视频二区| 久久久久99|