如何理解 Tracker 返回的紧凑对等节点列表
简介
为了减小 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” 意味着追踪器返回的是使用紧凑格式表示的对等节点列表,该列表可用于建立与其他共享文件用户的连接。