使用libtorrent-python下载种子

18 投票
2 回答
16162 浏览
提问于 2025-04-16 20:42

我有以下的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 个回答

3

你看到的下载速度很可能是来自实际的元数据下载,也就是从其他用户那里下载的.torrent文件。一旦这个.torrent文件下载完成,下载就开始了。

看起来你已经有了一些属于这个种子的文件,所以下载被暂停了,这些文件正在被检查。也就是说,这些文件会被读取、计算哈希值,然后和.torrent文件里的哈希值进行对比。

最后一列显示的是在这些文件中找到的与哈希值匹配的兆字节数,而倒数第二列则显示种子的状态,比如正在检查。

如果你等到检查完成,下载应该会继续进行。

更好的是,如果你在退出时保存了恢复数据,下次启动时加载回来,就不需要每次都重新检查了。

14

问题其实很简单。保存文件的路径并不存在,所以libtorrent这个库在下载的时候,只要不需要清空缓存就能正常工作。但是一旦它尝试写文件的时候,就失败了,导致下载无法继续,因此出现了变慢和最终停止的情况。一旦添加了一个有效的路径,它就能正常工作了。

撰写回答