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

参考链接

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,002评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,777评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,341评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,085评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,110评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,868评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,528评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,422评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,938评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,067评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,199评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,877评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,540评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,079评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,192评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,514评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,190评论 2 357

推荐阅读更多精彩内容

  • 简介 为了在一个 BitTorrent 下载群体中找到其他的节点,一个客户端会向一个追踪器发出宣告自己的请求。这个...
    IMFile阅读 287评论 0 0
  • BitTorrent 是一种用于分发文件的协议。它通过 URL 标识内容,并且旨在与 Web 网络无缝集成。相对于...
    IMFile阅读 230评论 0 0
  • DHT(Distributed Hash Table)分布式哈希表 是分布式计算系统中的一个类别,是一种分布式系统...
    IMFile阅读 199评论 0 0
  • BT协议 bt种子文件 编码 bencode bencode 有 4 种数据类型: string, integer...
    云烟1f3bca320ba6阅读 3,434评论 0 1
  • 概述 传统上,在 BitTorrent 网络中,20 字节的 Peer ID 字段用于标识客户端,并且通常包含了客...
    IMFile阅读 120评论 0 0