2016-10-10 18 views
0

Я использую libtorrent 1.0.9 и настраиваемые привязки (воспроизводимые с помощью python). Иногда я не могу загрузить магниты, потому что они застряли без метаданных (в то время как есть 200 узлов DHT). Я в состоянии воспроизвести проблему с этим магнитом:Нет метаданных скачать

magnet:?xt=urn:btih:565DB305A27FFB321FCC7B064AFD7BD73AEDDA2B&dn=bbb_sunflower_1080p_60fps_normal.mp4&tr=udp%3a%2f%2ftracker.openbittorrent.com%3a80%2fannounce&tr=udp%3a%2f%2ftracker.publicbt.com%3a80%2fannounce&ws=http%3a%2f%2fdistribution.bbb3d.renderfarming.net%2fvideo%2fmp4%2fbbb_sunflower_1080p_60fps_normal.mp4 

Между тем в других клиентах торрент (qBittorrent, Vuze) он получает метаданные очень быстро. Он воспроизводится следующим кодом:

import libtorrent as lt 
import time 

session = lt.session() 
session.listen_on(6881, 6891) 
session.add_extension('ut_metadata') 
session.add_extension('ut_pex') 
session.add_extension('metadata_transfer') 
session.add_dht_router("router.utorrent.com", 6881) 
session.add_dht_router("router.bittorrent.com", 6881) 
session.add_dht_router("dht.transmissionbt.com", 6881) 
session.add_dht_router("dht.aelitis.com", 6881) 
session.start_dht() 
session.start_lsd() 
session.start_upnp() 
session.start_natpmp() 

params = { 'save_path': '/tmp/'} 
link ="magnet:?xt=urn:btih:565DB305A27FFB321FCC7B064AFD7BD73AEDDA2B&dn=bbb_sunflower_1080p_60fps_normal.mp4&tr=udp%3a%2f%2ftracker.openbittorrent.com%3a80%2fannounce&tr=udp%3a%2f%2ftracker.publicbt.com%3a80%2fannounce&ws=http%3a%2f%2fdistribution.bbb3d.renderfarming.net%2fvideo%2fmp4%2fbbb_sunflower_1080p_60fps_normal.mp4" 
handle = lt.add_magnet_uri(session, link, params) 

print('downloading metadata...') 
while (not handle.has_metadata()): 
    status=session.status() 
    print('dht nodes: ', status.dht_nodes) 
    time.sleep(1) 
print ('got metadata, starting torrent download...') 
while (handle.status().state != lt.torrent_status.seeding): 
    print('%d %% done' % (handle.status().progress*100)) 
    time.sleep(1) 

Что я делаю неправильно?

ответ

2

Это, скорее всего, связано с проблемой в серии 1.0.x, где некоторые из первых ответов DHT заставят узел изменить свой идентификатор узла (для соответствия его внешнему IP-адресу, см. this post).

Это делается путем перезапуска узла DHT. Любой в полете торрент, объявленный в то время, будет потерян. Ожидание 15 минут для следующего анонса должно сделать анонс. Другой вариант - дождаться dht_bootstrap_alert перед добавлением первого торрента в сеанс.

Эта проблема была устранена в версиях 1.1.x.

+0

Спасибо! Это сводило меня с ума – user37741