简介
为了减小 Tracker 响应的大小并降低 Tracker 的内存和计算要求,Tracker 可以将对等节点以打包字符串的形式返回,而不是作为bencoded 列表返回。
在本文档中,“MUST”,“MUST NOT”,“REQUIRED”,“SHALL”,“SHALL NOT”,“SHOULD”,“SHOULD NOT”,“RECOMMENDED”,“MAY” 和 “OPTIONAL” 这些关键词的解释请参考 IETF RFC 2119 中所述。
概述
按照 BitTorrent 协议规范,希望传输文件的对等节点会联系一个中央 Tracker 。该 Tracker 会返回一个正在传输该文件的对等节点列表。这个对等节点列表是以一系列 bencoded 字典的形式实现的。列表中的每个字典包含三个字段:peer id、ip 和 port。
其中,peer id 是20个字节加上 3 个字节的 bencoding 额外负荷。ip 是一个字符串,包含一个域名或 IP 地址,以及一个整数端口号。ip 的长度可变,但是由于它在最长形式下是一个域名,所以不能超过 255 个字节,再加上 4 个字节的 bencoding 额外负荷。Bencoded 整数也是可变长度的,但由于它表示的是一个端口号,所以长度不会超过 7 个字节,包括 bencoding 额外负荷。
根据 BitTorrent 协议规范,BitTorrent 协议中的对等节点列表以 bencoded 字典的形式存储,每个字典包含peer id、ip 和 port 三个字段,分别表示对等节点的唯一标识、IP 地址和端口号。
故,
total peer list length in bytes < n * ( 23 + 259 + 7 )
现在普遍使用一种紧凑的格式来表示每个对等节点,其中每个对等节点仅使用 6 个字节。前 4 个字节包含 32 位的 IPv4 地址,剩下的两个字节包含端口号。无论是地址还是端口号,都使用网络字节顺序。
建议 trackers 默认返回紧凑格式。通过在 announce URL中包含”compact=0“,客户端向追踪器建议使用原始格式,类似地,”compact=1“则建议tracker 使用紧凑格式。然而,”compact“键值对仅供参考:tracker 可以选择使用任一格式进行返回。”compact“是一个建议性质的设定,以便 tracker 可能只支持紧凑格式。然而,客户端必须继续支持两种格式。
根据上述描述,建议 tracker 在默认情况下返回紧凑格式的对等节点列表。通过在 announce URL 中指定相应的参数,客户端可以建议 tracker 使用原始格式或紧凑格式。然而,最终 tracker 可以自行决定返回哪种格式。客户端必须同时支持两种格式。
例:
GET /announce?peer_id=aaaaaaaaaaaaaaaaaaaa&info_hash=aaaaaaaaaaaaaaaaaaaa &port=6881&left=0&downloaded=100&uploaded=0&compact=1
BitTorrent 协议中的”compact format“数据格式。在传统的 BitTorrent tracker 响应中,使用一个名为”peers”的键来表示对等节点列表,其值是一个 bencoded(一种编码格式)的列表。
然而,在”compact format”中,依然使用相同的”peers”键,但是该键的值是一个经过 bencode 编码的字符串,而不是列表形式。与传统格式不同的是,”compact format”中不包含对等节点的 ID(peer id)。虽然缺乏对等节点 ID 的信息,但是这种紧凑格式已经被广泛使用多年,并且并未引起任何问题。
这种”compact format”格式得到了 BitTorrent 主流客户端 IMFile、qBittorrent、libtorrent、uTorrent 等大多数客户端的支持。
总结
在点对点文件共享网络中,当您连接到一个Tracker 以获取共享文件的其他用户信息时,Tracker 通常会返回一个对等节点列表,其中包含正在共享该文件的其他用户的信息。这些信息可以包括IP地址、端口号等。
Tracker Returns Compact Peer Lists 中的”Compact Peer Lists”是一种格式或方式,用于表示对等节点列表的紧凑形式。相比于其他格式,如详细节点列表,紧凑对等节点列表使用更少的数据来表示节点信息,从而减少网络流量和资源消耗。
通常情况下,紧凑对等节点列表使用二进制表示,并且采用特定的编码方案。它通常包括节点的IP地址和端口号,可以通过解码和处理该列表来获取节点的具体信息。
总而言之,”Tracker Returns Compact Peer Lists”意味着追踪器返回的是使用紧凑格式表示的对等节点列表,该列表可用于建立与其他共享文件用户的连接。
参考链接
- http://www.bittorrent.org/beps/bep_0023.html
- https://blog.imfile.io/2023/06/13/bittorrent-xie-yi-gui-fan/
- https://datatracker.ietf.org/doc/html/rfc1034
- http://www.ietf.org/rfc/rfc2119.txt