Загрузка торрента с помощью libtorrent-python - PullRequest
16 голосов
/ 02 июля 2011

У меня есть следующий код Python:

import libtorrent as lt
import time

ses = lt.session()
ses.listen_on(6881, 6891)
params = {
    'save_path': '/home/downloads/',
    'storage_mode': lt.storage_mode_t(2),
    'paused': False,
    'auto_managed': True,
    'duplicate_is_error': True}
link = "magnet:?xt=urn:btih:4MR6HU7SIHXAXQQFXFJTNLTYSREDR5EI&tr=http://tracker.vodo.net:6970/announce"
handle = lt.add_magnet_uri(ses, link, params)
ses.start_dht()

print 'downloading metadata...'
while (not handle.has_metadata()):
    time.sleep(1)
print 'got metadata, starting torrent download...'
while (handle.status().state != lt.torrent_status.seeding):
    s = handle.status()
    state_str = ['queued', 'checking', 'downloading metadata', \
                'downloading', 'finished', 'seeding', 'allocating']
    print '%.2f%% complete (down: %.1f kb/s up: %.1f kB/s peers: %d) %s %.3' % \
                (s.progress * 100, s.download_rate / 1000, s.upload_rate / 1000, \
                s.num_peers, state_str[s.state], s.total_download/1000000)
    time.sleep(5)

Что, кажется, работает нормально, но затем замедляется до менее чем байта / с:

$ python test.py 
downloading metadata...
got metadata, starting torrent download...
0.00% complete (down: 195.0 kb/s up: 8.0 kB/s peers: 28) checking 3.069
0.00% complete (down: 133.0 kb/s up: 5.0 kB/s peers: 28) checking 3.342
0.00% complete (down: 29.0 kb/s up: 1.0 kB/s peers: 28) checking 3.359
0.00% complete (down: 5.0 kb/s up: 0.0 kB/s peers: 28) checking 3.398
0.00% complete (down: 4.0 kb/s up: 0.0 kB/s peers: 28) checking 3.401
0.00% complete (down: 0.0 kb/s up: 0.0 kB/s peers: 28) checking 3.405
0.00% complete (down: 0.0 kb/s up: 0.0 kB/s peers: 28) checking 3.408
0.00% complete (down: 0.0 kb/s up: 0.0 kB/s peers: 28) checking 3.412

Он замедляется и никогда не завершается. Есть идеи, почему это происходит?

Ответы [ 2 ]

13 голосов
/ 03 августа 2011

Проблема оказалась тривиальной.Файл save_path не существует, поэтому библиотека libtorrent загружалась до тех пор, пока ей не нужно было очищать кэш, но, как только она попыталась записать файл, она не смогла и не могла продолжить загрузку, что привело к замедлению и возможному останову.После добавления существующего пути он работал нормально.

3 голосов
/ 31 июля 2011

Скорость загрузки, которую вы видите, скорее всего зависит от фактической загрузки метаданных (то есть .torrent-файла, загруженного с ваших пиров). Как только файл .torrent был загружен, он запускается. В этом случае.

Похоже, что у вас уже есть некоторые файлы, которые принадлежат этому торренту, поэтому загрузка останавливается и эти файлы проверяются. то есть фрагмент считывается, хэшируется и сравнивается с фрагментами хеша в файле .torrent.

В последнем столбце показано количество мегабайт, найденных в файлах, которые соответствуют хэшам, в последнем столбце, кроме одного, указано состояние торрента, т.е. проверка.

Если вы дождетесь окончания проверки, загрузка должна возобновиться.

Еще лучше: если вы сохраняете данные возобновления при выходе и загружаете их обратно при запуске, вам не нужно перепроверять каждый раз.

...