关于BitTorrent 协议的几点感想

简介: 关于BitTorrent 协议的几点感想 1) 使用文件info的hash值作为文件的id(即Info_hash) 为什么不使用顺序编号或者GUID之类的东西呢? 如果采用顺序编号,谁来编号,发布者?还是某个服务器?如果是发布者,两个不同的发布者就不能保证编号不重复。

关于BitTorrent 协议的几点感想

1) 使用文件infohash值作为文件的id(即Info_hash

为什么不使用顺序编号或者GUID之类的东西呢?

如果采用顺序编号,谁来编号,发布者?还是某个服务器?如果是发布者,两个不同的发布者就不能保证编号不重复。如果是某个服务器,那这个ID只在该服务器的势力范围内有效,不够灵活,也增加了发布的复杂度。

至于GUID,可能是个办法。但感觉不太保险,谁知道发布者的GUID从哪儿来的。

但使用文件infohash值作为文件的idInfo_hash)就完全不一样了。

文件info中包含所有片段的Hash值,所以infohash值其实和文件内容是有对应关系的。除非2个文件的内容完全一样,并且它们的发布者给它们设的属性(文件名,片段长度等)完全相同,否则hash值发生冲突的概率小到可以忽略不计。

这个Info_hash本身就能标识文件,只要种子和下载者提供的Info_hash相同,就可以认为它们指的是同一个文件。

这样一个.torrent对应多个tracer也是有可能的。

 

2)数据块的管理

对于多个文件,按文件顺序将所有文件的片段统一编号,管理,显然简化了处理。

 

3)为什么使用bencoding编码

-交换性好(比较2进制编码)

-机器读取方便

-解编码器比较容易实现(比较其他文本编码,如XML

-可以在字符串中自由包含2进制数据,不用转义。

-可扩展(比较java的属性文件)

-人工可读

 

4‘choke’,‘unchoe’,‘interested’,not interested’的作用

‘choke’,‘unchoe’告诉对方,我能不能或愿不愿意给你发数据。

interested’,not interested’ 告诉对方,我愿不愿意接受数据。

我想暂停的时候,应该发送unchoenot interested中止对方的数据收发。

 

疑问:

Peer_id的作用,以及Peer_id为什么要通过hash运算得到?不清楚

参考:

http://blog.csdn.net/honkerhero/archive/2007/07/03/1677022.aspx     

 

 

相关文章
|
8月前
|
安全 网络协议 物联网
不看后悔系列之一篇搞懂LinuxCentOS搭建MQTT服务器及客户端操作使用
linux CentOS上搭建MQTT服务器并不难,主要就是用到了mosquitto这款消息代理服务软件。其采用发布/订阅模式传输机制,轻量、简单、开放并易于实现,被广泛应用于物联网之中。
1376 0
|
3月前
答知识星球朋友疑问:执行 ABAP 代码出现超时的原因,背后的理论和解决方案试读版
答知识星球朋友疑问:执行 ABAP 代码出现超时的原因,背后的理论和解决方案试读版
17 0
|
5月前
|
监控 项目管理
通俗易懂的方式理解项目管理的49个过程(追妹子案例)
通俗易懂的方式理解项目管理的49个过程(追妹子案例)
53 0
|
7月前
|
SQL 安全 前端开发
Web安全性测试包括哪些要点?梳理下,总算搞明白了
Web安全性测试包括哪些要点?梳理下,总算搞明白了
119 0
Web安全性测试包括哪些要点?梳理下,总算搞明白了
|
负载均衡 安全 网络协议
网络编程懒人入门(十五):外行也能读懂的网络硬件设备功能原理速成
本文是《网络编程懒人入门》系列文章的第15篇,本篇将继续以通俗易懂的文字,帮你无脑理解各种基础网络硬件设备的功能原理。
94 0
|
负载均衡 应用服务中间件 Apache
深入浅出学习透析Nginx服务器的基本原理和配置指南「初级实践篇」
深入浅出学习透析Nginx服务器的基本原理和配置指南「初级实践篇」
178 0
深入浅出学习透析Nginx服务器的基本原理和配置指南「初级实践篇」
|
机器学习/深度学习 算法 API
性能世界第二的半定规划SDP是什么?怎么用?此文全面解答
半定规划作为作为重要的优化建模工具被广泛应用于机器学习、信号处理、计算机视觉、以及量子计算等领域。MindOpt新版本V0.23.0中新增了半定规划SDP求解器,测评成绩世界第二。
性能世界第二的半定规划SDP是什么?怎么用?此文全面解答
|
关系型数据库 中间件 MySQL
分布式基础理论知识点-2pc协议(面试常问知识点)
分布式事务专题一直是面试的重点,这篇文章主要是讨论一下分布式事务中的2pc协议。如果你之前看过CAP和BASE理论,会对这篇文章的理解有更大的帮助。
327 0
分布式基础理论知识点-2pc协议(面试常问知识点)
|
网络协议 Unix Android开发
好家伙!计算机网络基础知识发布!(一)
如果说计算机把我们从工业时代带到了信息时代,那么计算机网络就可以说把我们带到了网络时代。随着使用计算机人数的不断增加,计算机也经历了一系列的快速发展,从大型通用计算机 -> 超级计算机 -> 小型机 -> 个人电脑 -> 工作站 -> 便携式电脑 -> 智能手机终端等都是这一过程的产物。计算机网络也逐渐从独立模式演变为了网络互联模式。
好家伙!计算机网络基础知识发布!(一)
|
域名解析 缓存 网络协议
好家伙!计算机网络基础知识发布!(二)
如果说计算机把我们从工业时代带到了信息时代,那么计算机网络就可以说把我们带到了网络时代。随着使用计算机人数的不断增加,计算机也经历了一系列的快速发展,从大型通用计算机 -> 超级计算机 -> 小型机 -> 个人电脑 -> 工作站 -> 便携式电脑 -> 智能手机终端等都是这一过程的产物。计算机网络也逐渐从独立模式演变为了网络互联模式。
好家伙!计算机网络基础知识发布!(二)