`
shonelau
  • 浏览: 17167 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Tracker 服务器源码分析之一:总述

阅读更多

Tracker 服务器源码分析之一:总述

作者:小马哥

日期:2004-5-29



       tracker服务器是BT下载中必须的角色。一个BT client 在下载开始以及下载进行的过程中,要不停的与 tracker 服务器进行通信,以报告自己的信息,并获取其它下载client的信息。这种通信是通过 HTTP 协议进行的,又被称为 tracker  HTTP 协议,它的过程是这样的:

       client 向 tracker 发一个HTTP 的GET请求,并把它自己的信息放在GET的参数中;这个请求的大致意思是:我是xxx(一个唯一的id),我想下载yyy文件,我的ip是aaa,我用的端口是bbb。。。

       tracker 对所有下载者的信息进行维护,当它收到一个请求后,首先把对方的信息记录下来(如果已经记录在案,那么就检查是否需要更新),然后将一部分(并非全部,根据设置的参数已经下载者的请求)参与下载同一个文件(一个tracker服务器可能同时维护多个文件的下载)的下载者的信息返回给对方。

       Client在收到tracker的响应后,就能获取其它下载者的信息,那么它就可以根据这些信息,与其它下载者建立连接,从它们那里下载文件片断。



关于client和tracker之间通信协议的细节,在“BT协议规范”中已经给出,这里不再重复。下面我们具体分析 tracker服务器的实现细节。



从哪里开始?

       要建立一个 tracker服务器,只要运行 bttrack.py 程序就行了,它最少需要一个参数,就是 –dfile,这个参数指定了保存下载信息的文件。Bttrack.py 调用 track.py 中的 track()函数。因此,我们跟踪到 track.py 中去看track() 函数。



Track.py:track()

       这个函数首先对命令行的参数进行检查;然后将这些参数保存到 config 字典中。在BT中所有的工具程序,都有类似的处理方式。



接下来的代码:

 

r = RawServer(Event(), config['timeout_check_interval'], config['socket_timeout']) 
t = Tracker(config, r)
r.bind(config['port'], config['bind'], True) 
r.listen_forever(HTTPHandler(t.get, config['min_time_between_log_flushes'])) t.save_dfile()
  
 


首先是创建一个 RawServer 对象,这是一个服务器对象,它将实现一个网络服务器的一些细节封装起来。不仅tracker服务器用到了 RawServer,我们以后还可以看到,由于每个 client端也需要给其它 client 提供下载服务,因此也同时是一个服务器,client的实现中,也用到了RawServer,这样,RawServer的代码得到了重用。关于 RawServer的详细实现,在后面的小节中进行分析。

接着是创建一个 Tracker对象。

然后让RawServer绑定在指定的端口上(通过命令行传递进来)。

最后,调用 RawServer::listen_forever() 函数,使得服务器投入运行。

最后,在服务器因某些原因结束运行以后,调用 Tracker::save_dfile() 保存下载信息。这样,一旦服务器再次投入运行,可以恢复当前的状态。





其它信息:

1、  BT源码的分布:

把BT的源码展开之后,可以看到有一些python程序,还有一些说明文件等等,此外还有一个BitTorrent目录。这些 python程序,实际是一些小工具,比如制作 metafile的btmakemetafile.py、运行tracker服务器的bttrack.py、运行BT client端的 btdownloadheadless.py 等等。而这些程序中,用到的一些 python 类的实现,都放在子目录 BitTorrent 下面。我们的分析工作,通常是从工具程序入手,比如 bttrack.py,而随着分析的展开,则重点是看 BitTorrenet子目录下的代码。

BT作者 Bram Cohen 在谈到如何开发可维护的代码的一篇文章中(http://www.advogato.org/article/258.html),其中提到的一条就是开发一些小工具以简化工作,我想BT的这种源码结构,也正是作者思想的一种体现吧。



2、  我们看到,python和我们以前接触的 c/c++ 不一样的第一个地方就是它的函数在定义的时候,不用指定参数类型。既然这样,那么,在调用函数的时候,你可以传递任意类型的参数进来。例如这样的函数:

 

 def foo(arg):


         print type(arg)


       


#        你可以这样来调用:


        a = 100


        b = “hello world”


        foo(a)


        foo(b)









        输出结果是:


        <type ‘int’>;


        <type ‘str’>;

  这是因为,第一次调用 foo()的时候,传递的是一个整数类型,而第二次调用的时候,传递的是一个字符串类型。



这种参数具有动态类型的特性,是 c/c++等传统的语言是所不具备的。这也是 python 被称为动态语言的一个原因吧。C++的高级特性模板,虽然也使得参数类型可以动态化,但使用起来,远没有python这么简单方便

 

分享到:
评论

相关推荐

    点量高性能Tracker服务器

    点量高性能Tracker服务器是一款专为Windows操作系统设计的高性能BT(BitTorrent)追踪器软件,尤其适合在Windows 2003 Server及以上版本的服务器环境中运行。Tracker服务器在BitTorrent网络中扮演着至关重要的角色,...

    下载工具tracker服务器列表.txt

    tracker服务器是BT下载中必须的角色。一个BTclient在下载开始以及下载进行的过程中,要不停的与tracker服务器进行通信,以报告自己的信息,并获取其它下载client的信息。

    国内常用的tracker地址.txt

    当它收到一个请求后,首先把对方的信息记录下来(如果已经记录在案,那么就检查是否需要更新),然后将一部分(并非全部,根据设置的参数已经下载者的请求)参与下载同一个文件(一个tracker服务器可能同时维护多个...

    tracker服务器.txt

    tracker服务器地址

    tracker服务器列表

    tracker列表,下载加速常用。

    BitCometTracker_0.5

    BitCometTracker_0.5是一款专为Windows操作系统设计的Tracker服务器软件,它主要用于支持P2P(peer-to-peer)网络中的文件分享,尤其是BitTorrent协议。Tracker服务器在BitTorrent网络中扮演着至关重要的角色,它...

    KCF_Tracker MATLAB 源码

    **KCF Tracker MATLAB 源码详解** KCF(Kernelized Correlation Filter)是一种高效、实时的目标跟踪算法,由Henriques、Bolme和Ringach在2015年提出。KCFTracker在计算机视觉领域广泛应用,尤其在视频处理和目标...

    GpsTracker源码.zip

    【标题】"GpsTracker源码.zip"是一个与Android应用程序相关的源码压缩包,它包含了一个简单的GPS追踪器的实现。对于那些想要学习如何在Android平台上开发定位跟踪功能的开发者来说,这是一个很好的学习资源。 ...

    xbt_tracker

    "xbt_tracker"是一个基于VC++编写的Tracker服务器源代码,它是BitTorrent协议的一个关键组成部分。BitTorrent是一种点对点(P2P)文件分享协议,用于高效地分发大容量数据,如软件、视频和音乐。Tracker服务器在其中...

    安卓Android源码——GpsTracker源码.zip

    "安卓Android源码——GpsTracker源码.zip" 提供的是一个针对Android平台的GpsTracker应用的源代码。GpsTracker通常是一个用于追踪和记录GPS定位数据的应用,它可以帮助开发者了解如何在Android系统中利用GPS服务进行...

    tracker(99条)每日自动更新链接,包括镜像地址

    tracker(99条)每日自动更新链接,包括镜像地址

    Android源码——GpsTracker源码.zip

    GpsTracker是Android应用程序中用于追踪和管理GPS定位的一种实现方式。本文将深入探讨GpsTracker的源码,解析其工作原理和关键功能,以帮助开发者更好地理解和利用Android的GPS服务。 首先,我们了解GpsTracker的...

    自动获取tracker文件并转换为Aria2可用格式

    Tracker服务器是一个中心节点,它维护着参与特定种子的客户端列表,负责协调下载和上传活动,确保P2P网络的高效运行。Tracker文件通常包含这些Tracker服务器的地址,通过它们,Aria2能够获得必要的信息来连接到其他...

    Android GpsTracker源码.rar

    【Android GpsTracker源码分析】 Android GpsTracker是一款基于Android平台的应用程序,主要用于实时追踪和记录设备的位置信息。这个项目的核心是利用Android系统提供的GPS(全球定位系统)服务来获取经纬度坐标,...

    matomo-java-tracker:Matomo Tracking HTTP API的官方Java实现-源码

    通过深入学习Matomo Java Tracker的源码,可以了解其内部工作原理,这对于优化追踪性能、调试问题或者扩展功能都非常有帮助。此外,熟悉这个库也有助于理解Matomo的HTTP API,从而能够更好地与其他编程语言集成...

    video_spot_tracker_v08.11-1_tracker_tracking_

    视频分析在当今的智能监控、媒体处理和科学研究等领域中扮演着至关重要的角色,而视频斑点追踪(Video Spot Tracker)是其中一种核心技术。本文将围绕"video_spot_tracker_v08.11-1_tracker_tracking_"这一软件,...

    Android GpsTracker源码.zip

    总之,Android GpsTracker源码是理解GPS定位机制的关键,通过深入分析其内部逻辑,开发者可以更好地掌握如何在Android应用中实现精准且高效的定位服务。在实际开发中,根据具体需求对源码进行调整和优化,能够为用户...

Global site tag (gtag.js) - Google Analytics