resolved reqq question

reqq question
=============
reqq:
  An integer, the number of outstanding request messages this client supports
  without dropping any. The default in in libtorrent is 250.

  "handshake message" @ "Extension Protocol"
    @ http://www.bittorrent.org/beps/bep_0010.html

TODO: maybe by requesting all pieces at once we are exceeding this limit? maybe
      we should request as we receive pieces?

answer
======
almost every single peer I encountered (for brief 10 minutes... which I think
is enough) had 255 as reqq value and the number of metadata pieces we requested
very rarely exceeded 20... I think it's fair to assume that exceeding "that
limit" will never be a question, and requesting the next piece as we receive
the previous one might increase the latency, unnecessarily.
This commit is contained in:
Bora Alper 2018-08-03 16:16:33 +03:00
parent 4b9b354171
commit 85fb2f5ea9

View File

@ -150,15 +150,6 @@ func (l *Leech) doExHandshake() error {
} }
func (l *Leech) requestAllPieces() error { func (l *Leech) requestAllPieces() error {
// reqq
// An integer, the number of outstanding request messages this client supports without
// dropping any. The default in in libtorrent is 250.
//
// "handshake message" @ "Extension Protocol" @ http://www.bittorrent.org/beps/bep_0010.html
//
// TODO: maybe by requesting all pieces at once we are exceeding this limit? maybe we should
// request as we receive pieces?
// Request all the pieces of metadata // Request all the pieces of metadata
nPieces := int(math.Ceil(float64(l.metadataSize) / math.Pow(2, 14))) nPieces := int(math.Ceil(float64(l.metadataSize) / math.Pow(2, 14)))
for piece := 0; piece < nPieces; piece++ { for piece := 0; piece < nPieces; piece++ {
@ -318,7 +309,7 @@ func (l *Leech) Do(deadline time.Time) {
l.OnError(errors.Wrap(err, "doExHandshake")) l.OnError(errors.Wrap(err, "doExHandshake"))
return return
} }
err = l.requestAllPieces() err = l.requestAllPieces()
if err != nil { if err != nil {
l.OnError(errors.Wrap(err, "requestAllPieces")) l.OnError(errors.Wrap(err, "requestAllPieces"))