7

多くのサーバーに移動するための大きなファイルがあります。今のところrsyncを使用していますが、bittorentを試してみたいと思います。

私はPythonのbittorentクライアントであるDelugeのコードを研究していますが、それはツイストを使用しており、非常に複雑です。あなたは何か高いレベルを知っていますか?

編集:FacebookがBittorentを使用してコードをデプロイしていることを読みました。たぶん彼らはそのために彼らのlibを公開しました、しかし私はそれを見つけることができません。聞いたことがありますか?

4

2 に答える 2

6

私は間違いなくlibtorrent-rasterbarをお勧めします。これは、Pythonバインディングを備えたC++ライブラリです。Deluge、Transmission、Miroおよび他の多くのbittorrentクライアントに電力を供給するものと同じもの。

他のlibtorrent(rTorrentプロジェクトの一部であるもの)とは対照的に、これは活発に開発されており、DHT、メタデータ転送、ピア交換(PEX)などの独自のuTorrent拡張機能などの最新のプロトコル拡張機能をすべてサポートしています。

APIは非常によく文書化されています。

次の完全に機能する単純なクライアントの例からわかるように、基礎となるプロトコルのすべてのビットを理解する必要はありません(もちろん、理解するときに非常に役立ちます)。

#!/bin/python
# Copyright Arvid Norberg 2008. Use, modification and distribution is
# subject to the Boost Software License, Version 1.0. (See accompanying
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)


import libtorrent as lt
import time
import sys

ses = lt.session()
ses.listen_on(6881, 6891)

info = lt.torrent_info(sys.argv[1])
h = ses.add_torrent({'ti': info, 'save_path': './'})
print 'starting', h.name()

while (not h.is_seed()):
    s = h.status()

    state_str = ['queued', 'checking', 'downloading metadata', 'downloading', \
        'finished', 'seeding', 'allocating', 'checking fastresume']
    print '\r%.2f%% complete (down: %.1f kb/s up: %.1f kB/s peers: %d) %s' % \
        (s.progress * 100, s.download_rate / 1000, s.upload_rate / 1000, \
        s.num_peers, state_str[s.state]),
    sys.stdout.flush()

    time.sleep(1)

print h.name(), 'complete'

PS Facebookには、オープンソースプロジェクト専用のページがhttp://developers.facebook.com/opensource/にあります。リストされているbittorrentの実装はありません。

于 2011-03-06T18:56:01.010 に答える
2

オリジナルのBitTorrentクライアントはPythonで書かれています。あなたはそれをチェックしましたか?

于 2011-01-20T17:28:56.820 に答える