BitTorrent协议标准之数据包格式

BT中Peer和Peer之间交互的数据包的格式除了握手包之外都是:包长度(Int)+包体。

当两个Peer连接后,要首先向对方发送握手包,如果握手失败,连接将关闭。握手包的格式是:
字符串长度+字符串+保留字段+info_hash+peer_id
字符串长度:后面的字符串长度,1个Byte
字符串:标识协议的字符串。在1.0的bt协议中为"BitTorrent protocol"
保留字段:8个字节,用于协议扩展,无扩展的时候全为0,使用的时候从后向前开始使用。
info_hash:20个字节,就是用于向tracker请求的那个info_hash
peer_id:20个字节,各个BT软件对peer_id的命名方法不一样,大致有几种类型,这个以后再说。
当本地节点主动连接到远端节点后,就应当立即向远端节点发送握手包,远端节点接收连接后等等握手包的到来,当握手包接收后立即回应握手包。当远端节点接收 到握手包后,它会首先看info_hash字段所代表的任务是否存在,若不存在,那就应该关闭连接。当远端节点回应握手包后,本地节点应当判断该节点的 peer_id,如果它有从tracker那里得知远端节点的peer_id,若发现pere_id不符合,本地节点应当关闭连接。

剩下的Peer之间的所有交互数据包格式是:包长度(Int,4个Byte长度)+包类型(1个Byte)+消息体,前面的包长度和包类型是定的,后面的消息体因包类型不同而具体格式不同。主要的包有下面几种:
keep-alive: <len=0000>
keep-alive包(保活/心跳包)就是一个包长度设置为0的包,也没有包类型字段,其内容就是0000,它的时间间隔是2分钟。
choke:<len=0001><type=0>
把接收方阻塞
unchoke:<len=0001><type=1>
把接收方取消阻塞
interested:<len=0001><type=2>
关注接收方
not interested:<len=0001><type=3>
取消关注接收方
have:<len=0005><type=4><piece index>
告诉接收方的Peer,发送方拥有某一个piece的数据,piece的index是以0开始的<piece index>
这个包是非常频繁的包,BT客户端的实现应该设计一些技巧在不减少信息发布的情况下减少这个包的传输。比如某个Peer已经有该piece了,显然就不应 该向它发送了。或者某个Peer它选择性下载,根本不需要下载这个piece,那也不要给它发送了。或者已经告诉过它一次了,就不要再告诉它了,等等。
bitfield:<len=0001+X><type=5><bitfield>
bitfield包一般在两个节点完成握手之后就要发送,当然,如果节点一个piece都没有,就没有必要发送了。这个包是变长的,取决于有多少个 piece,X就是bitfield的长度,bitfield里第一个字节的高位bit就对应着第一个piece(index=0)。由于piece的个 数不一定能被8整除,所以最后可能有没有用到的bit,那些bit全设为0就行了。peer在接收到该包后,要判断bitfield是否合法,即 piece个数是否合法,不合法则要关闭连接。
request:<len=0013><type=6><index><begin><length>
数据请求包,index:整型,表示piece index,begin:整型,表示offset in the piece。length:整型,表示请求的数据的长度。关于这个block的长度,众说纷纭,有的说16K,有的32K,有的说只要不超过128K就 好,等等,我觉得,这个得看实现BT协议的人,如果它的客户端做的就只支持16K,它有很多用户了,你再做BT客户端,你要跟它兼容,你就得支持16K, 所以我觉得,自己在程序中控制只要小于128K的请求都回应,向其他人发送request的时候,就根据它是什么客户端,默认就给它发个16K的这种就可 以了,整这么复杂干啥~
piece:<len=0009+X><type=7><index><begin><block>
回应的Block数据,X便是block的长度,index是piece index,begin是block在piece中的offset,block便是二进制数据了。
cancel:<len=0013><type=8><index><begin><length>
这个包跟request包一样,就是type不一样,它就表示把对应的那个request给取消掉。
port:<len=0003><type=9><listen port>
port包,是用来告诉接收方节点,发送方节点支持DHT,并且DHT监听的端口是listen port。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值