继续BT的研究-第二部份关于BT中的tracker 上次关于BT的研究主要是研究了BT文件的静态文件结构主是.torrent文件的结构,今天又看了libbt的代码并调试跟踪了btlist,这两天看了关于bt传输的文档,初步跟踪了bt的传输部份的代码这里做一个记录整理。 (一)关于BT的服务器 BT服务器主要有以下几个要素 (1)服务器上要运行一个tracker (2)运行一个web server (3)把.torrent的文件做好关联 (4)生成一个有效的种子文件 (5)把种子文件放到网页上 (二)关于BT中的tracker 这个就是BT之精华所在,是BT技术的灵魂,当建立连接的时候,tracker从所有下载者那里收集信息并帮助他们随机的配对,这个有点像P2P的打孔服务器,通过这个东东帮助下载者建立基于TCP的联接的通道,所有的过程是基于HTTP协议的。 所有的下载者通过周期性的与tracker联系报告他们的进度和信息,通过不同的连接上传和下载他们数据,连接是TCP连接,应用的是BitTorrent peer协议 (三)关于BT代码的分析 这部份代码主要要看btget.c这个函数,因为这个函数库用了两个第三方的开源库,所以要想门儿清最好先了解一下libcurl和openssl两个工程。 ctx_register( ctx, dl);这一句代码是取tracker文件的 int ctx_register( struct btContext *ctx, unsigned download) assert(download<ctx->downloadcount); main函数有一段循环的代码应该就是收发数据的部份了,今天就记到这儿,明天再继续吧。 关于tracker文件格式做一个补充说明 例子: * Tracker GET requests have the following keys urlencoded - * Tracker responses are bencoded dictionaries. 具体代表的含义明天再继续了,老婆刚才又生气了,原因是我刚刚让她不要干扰我工作
|
关于BT中的tracker
最新推荐文章于 2024-08-09 07:51:10 发布