發新話題
打印

什麼是BT,BT的概念

[Close]

什麼是BT,BT的概念

BitTorrent協議(簡稱BT,俗稱比特洪流、BT下載、變態下載)是一個網絡文件傳輸協議,它能夠實現點對點文件分享的技術。比起其他點對點的協議,它更有多點對多點的特性,這個特點簡單的說就是:下載的人越多,速度越快。下載完不馬上關閉BitTorrent軟件,就可以成為種子(擁有完整的檔案者)分流讓其他人下載。

原理簡述
BT原理普通的HTTP/FTP下載使用TCP/IP協議,BitTorrent協議是架構於TCP/IP協議之上的一個P2P文件傳輸協議,處於TCP/IP結構的應用層。 BitTorrent協議本身也包含了很多具體的內容協議和擴展協議,併在不斷擴充中。

根據BitTorrent協議,文件發佈者會根據要發佈的文件生成提供一個.torrent文件,即種子文件,也簡稱為「種子」。

.torrent文件本質上是文本文件,包含Tracker信息和文件信息兩部分。Tracker信息主要是BT下載中需要用到的Tracker伺服器的地址和針對Tracker伺服器的設置,文件信息是根據對目標文件的計算生成的,計算結果根據BitTorrent協議內的B編碼規則進行編碼。它的主要原理是需要把提供下載的文件虛擬分成大小相等的塊,塊大小必須為2k的整數次方(由於是虛擬分塊,硬碟上並不產生各個塊文件),並把每個塊的索引信息和Hash驗證碼寫入.torrent文件中;所以,.torrent文件就是被下載文件的「索引」。

下載者要下載文件內容,需要先得到相應的.torrent文件,然後使用BT客戶端軟件進行下載。

下載時,BT客戶端首先解析.torrent文件得到Tracker地址,然後連接Tracker伺服器。Tracker伺服器回應下載者的請求,提供下載者其他下載者(包括發佈者)的IP。下載者再連接其他下載者,根據.torrent文件,兩者分別對方告知自己已經有的塊,然後交換對方沒有的數據。此時不需要其他伺服器參與,分散了單個線路上的數據流量,因此減輕了伺服器負擔。

下載者每得到一個塊,需要算出下載塊的Hash驗證碼與.torrent文件中的對比,如果一樣則說明塊正確,不一樣則需要重新下載這個塊。這種規定是為了解決下載內容準確性的問題。

一般的HTTP/FTP下載,發佈文件僅在某個或某幾個伺服器,下載的人太多,伺服器的頻寬很易不勝負荷,變得很慢。而BitTorrent協議下載的特點是,下載的人越多,提供的頻寬也越多,種子也會越來越多,下載速度就越快。

而有些人下載完成後關掉下載任務,提供較少量數據給其他用戶,為盡量避免這種行為,在非官方BitTorrent協議中存在超級種子的演算法。這種演算法允許文件發佈者分幾步發佈文件,發佈者不需要一次提供文件所有內容,而是慢慢開放的下載內容的比例,延長下載時間。此時,速度快的人由於未下載完必須提供給他人數據,速度慢的人有更多機會得到數據。

DHT網絡  BT0.59版開始有@o@
目前,又發展出DHT網絡技術,使得無Tracker下載成為可能。

DHT全稱為分散式哈希表(Distributed Hash Table),是一種分散式存儲方法。在不需要伺服器的情況下,每個客戶端負責一個小範圍的路由,並負責存儲一小部分數據,從而實現整個DHT網絡的定址和存儲。使用支持該技術的BT下載軟件,用戶無需連上Tracker就可以下載,因為軟件會在DHT網絡中尋找下載同一文件的其他用戶並與之通訊,開始下載任務。

有些軟件(比特精靈)還會自動通過DHT搜索種子資源,構成種子市場。

另外,這裡使用的DHT演算法叫Kademlia(在eMule中也有使用,常把它叫做KAD,具體實現協議有所不同)。

這種技術好處十分明顯,就是大大減輕了Tracker的負擔(甚至不需要)。用戶之間可以更快速建立通訊(特別是與Tracker連接不上的時候)。

BT中相關概念
Tracker:收集下載者信息的伺服器,並將此信息提供給其他下載者,使下載者們相互連接起來,傳輸數據。

種子:指一個下載任務中所有文件都被某下載者完整的下載,此時下載者成為一個種子。發佈者本身發佈的文件就是原始種子。也指.torrent文件。

做種:發佈者提供下載任務的全部內容的行為;下載者下載完成後繼續提供給他人下載的行為。

BitTorrent與自由軟體
BitTorrent對於大型文檔和自由軟體如Linux、FreeBSD的發佈幫助很大。對於發佈數百MB以至數GB的檔案時,如Fedora的光碟鏡像格式檔,BitTorrent的使用能大大減低伺服器的數據流量從而減低發佈的成本。另外,一般有新版本軟體推出時,伺服器必定人山人海,使用BitTorrent也能大大減低繁忙時間伺服器的負擔。

對新手好有用

[ 本帖最後由 ltk0020 於 2006-6-29 15:43 編輯 ]

TOP

發新話題