Python 没有元数据下载

Python 没有元数据下载,python,bittorrent,dht,libtorrent,libtorrent-rasterbar,Python,Bittorrent,Dht,Libtorrent,Libtorrent Rasterbar,我使用的是libtorrent 1.0.9和自定义绑定(可通过python复制)。有时我无法下载磁铁,因为它们没有元数据(而DHT节点超过200个)。我可以用这个磁铁重现这个问题: magnet:?xt=urn:btih:565DB305A27FFB321FCC7B064AFD7BD73AEDDA2B&dn=bbb_sunflower_1080p_60fps_normal.mp4&tr=udp%3a%2f%2ftracker.openbittorrent.com%3a80%2fa

我使用的是libtorrent 1.0.9和自定义绑定(可通过python复制)。有时我无法下载磁铁,因为它们没有元数据(而DHT节点超过200个)。我可以用这个磁铁重现这个问题:

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
同时,在其他torrent客户端(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)

我做错了什么?

这很可能是由1.0.x系列中的问题引起的,其中来自DHT的一些最初响应将使节点更改其节点ID(以匹配其外部IP地址,请参阅)

它通过重新启动DHT节点来实现这一点。届时,任何飞行中的torrent广播都将丢失。等待15分钟等待下一次公告应该可以让公告通过。另一个选项是在将第一个torrent添加到会话之前等待


此问题已在1.1.x版本中修复。

谢谢!我快发疯了