基于BT协议的文件分发系统

时间:2022-12-19 23:45:56

基于BT协议的文件分发系统
构成:
    1.一个Web服务器:保存着种子文件
    2.一个种子文件:保存共享文件的一些信息(文件名,文件大小    ,Tracker服务器地址,torrent为后缀)
    3.一个Tracker服务器:保存当前下载某共享文件的所有下载者的IP和端口
    4.一个原始文件提供者:提供完整的共享文件
    5.一个网络浏览器
    6.一个或者多个下载者 :下载者本身称为客户端,其他下载者为peer
    
BT客户端下载一个共享文件的过程:
    客户端首先解析一个种子文件,
    获取待下载的共享文件的一些信息,
    包括Tracker服务器的地址,
    之后客户端通过Tracker的Ip和端口链接其他下载者,
    从他们那里下载文件,
    同时把自己已经下载的部分提供给其他下载者下载。
    
共享文件在逻辑上被划分为大小相同的块,称之为piece,每个piece大小通常为256K。
对于共享文件,1-256k为第一个piece ,257K-512K为第二个piece,依次类推...
种子文件包含每个piece的hash值。
BT协议规定使用Sha1算法对每个piece生成20字节的hash值作为每个piece的指纹。
每当客户端下载完一个piece时,即对该piece使用Sha1算法计算hash值,与种子文件保存的的piece的hash值比较,
如果一致,表明下载了一个完整而正确的piece。
一旦某个piece被下载。该piece即提供给其他peer下载。
在实际上传和下载中,每个piece又被划分为大小相同的slice,每个slice大小固定为16K。
peer之间每次传输以slice为单位。