загрузчик и загрузчик bittorrent-трекера в nodejs

#node.js #bittorrent

#node.js #битторрент

Вопрос:

Мне нужно настроить образец bittorrent tracker, seeder и leecher в nodejs. Я написал весь код, но он не работает, и я не знаю почему. Я загрузил трекер с помощью bittorrent-tracker, записал торрент-файл с помощью nt, также подключился к трекеру в качестве сеялки с помощью bittorrent-tracker (у bt-tracker есть как клиент, так и сервер).

Наконец я запустил еще один клиент, у которого был только торрент-файл и который был подключен к трекеру. Я могу видеть файлы в торренте (в клиенте downloading / leecher). Но сама загрузка файла не начнется.


Используемый код: // Tracker:

 var Server = require('bittorrent-tracker').Server
var port=6881

var server = new Server({
  udp: true, // enable udp server? [default=true]
  http: true // enable http server? [default=true]
})

server.on('error', function (err) {
  // fatal server error!
  console.log(err.message)
})

server.on('warning', function (err) {
  // client sent bad data. probably not a problem, just a buggy client.

  console.log(err.message)
})

server.on('listening', function () {
  console.log('tracker server is listening!')
})

// start tracker server listening!
server.listen(port)

// listen for individual tracker messages from peers:

server.on('start', function (addr, params) {
  console.log('got start message from '   addr)
  console.log('params in the message: '   JSON.stringify(params))
})

server.on('complete', function (addr, params) {})
server.on('update', function (addr, params) {})
server.on('stop', function (addr, params) {})

// get info hashes for all torrents in the tracker server
console.log(Object.keys(server.torrents))
 

// Код для создания и просмотра торрент-файлов

 var nt=require('nt');
var fs=require('fs');

//var rs=nt.make('udp://tracker.publicbt.com:80');
//rs.pipe(fs.createWriteStream('param.torrent'));

function postWrite(){
  var cl=require('bittorrent-tracker').Client;
  var parseTorrent=require('parse-torrent');
  var torrent=fs.readFileSync(__dirname   '/param.torrent');
  var parsedTorrent=parseTorrent(torrent);
  console.log(parsedTorrent);

  var peerId = new Buffer('81276382172123141133')
  var port = 6882

  var client = new cl(peerId, port, parsedTorrent)

  client.on('error', function (err) {
    console.log(err.message)
    // a tracker was unavailable or sent bad data to the client. you can probably ignore it
  })

  client.start()

  client.on('update', function (data) {
    console.log('got an announce response from tracker: '   data.announce)
    console.log('number of seeders in the swarm: '   data.complete)
    console.log('number of leechers in the swarm: '   data.incomplete)
  })

  client.once('peer', function (addr) {
    console.log('found a peer: '   addr) // 85.10.239.191:48623
  })

  // announce that download has completed (and you are now a seeder)
  client.complete();

  client.update()
}

function writeTorrentFile() {
  nt.makeWrite('param.torrent', 'udp://hola.127.0.0.1.xip.io:6881', '/Users/param/personal/nodejs/uploader/files', 
  //  ['hello-world.txt'], function(err, torrent){
    ['hello-world.txt'], {}, function(err, torrent){
      console.log(err);
      console.log(torrent);
      nt.read('param.torrent', function(err, torrent) {
        if (err) throw err;
        console.log('Info hash:', torrent.metadata.info);
      });

      postWrite();
    });
}
writeTorrentFile();
 

// Код для личера

 var BitTorrentClient = require('bittorrent-client');
var fs = require('fs');

var file = fs.readFileSync(__dirname   '/param.torrent')

var client = BitTorrentClient({
  maxPeers: 100,          // Max number of peers to connect to (per torrent)
  path: __dirname, // Where to save the torrent file data
  dht: true,              // Whether or not to enable DHT
  verify: true            // Verify previously stored data before starting
});

client.add(file);

client.on('torrent', function (torrent) {
  // torrent metadata has been fetched
  console.log(torrent.name)

  torrent.files.forEach(function (file) {
    console.log("selecting " file.name " for download");
    console.log(file.path)
    st=file.createReadStream()
    st.on('data', function(chunk){
      console.log(chunk)
    });
  })
})
 

Событие data в leecher никогда не вызывается — даже если оно входит в цикл files торрента!

Комментарии:

1. Опубликуйте код, который, по вашему мнению, является подозрительным.

2. добавлен код для трекера, загрузчика и пиявки.

Ответ №1:

Для загрузки вам нужно использовать настоящий торрент-клиент. Прямо сейчас вы просто используете bittorrent-tracker which, который просто сообщает серверу отслеживания, что вы сеялка, но на самом деле не содержит никакого кода для отправки файлов одноранговым узлам и фактически даже не прослушивает какие-либо порты. Чтобы на самом деле запустить, вы должны использовать полноценный торрент-клиент.

В вашем примере вы уже используете bittorrent-client (авторство мое), но я предлагаю вам перейти на использование webtorrent , поскольку я устарел bittorrent-client некоторое время назад.

Вот некоторый код для начальных файлов:

 var WebTorrent = require('webtorrent')
var client = new WebTorrent()
client.seed('/path/to/file', function (torrent) {
  console.log('Client is seeding:', torrent.magnetUri)
})
 

Вот полные документы по client.seed : https://github.com/feross/webtorrent/blob/master/docs/api.md#clientseedinput-opts-function-onseed-torrent-

Ответ №2:

createReadStream() Я думаю, вы хотите передать имя файла. В любом случае проверьте, не выдается ли событие «ошибка».

 // ...
var st = file.createReadStream(file)
st.on('data', console.log);
st.on('error', console.error);
 

Комментарии:

1. Я добавил обработчик ошибок как на st, так и на клиенте (в файле leecher), но я не получил никакого протоколирования от того же:-(. Кроме того, я использую библиотеку bittorrent-client для leecher, которая показана по этой ссылке: npmjs.org/package/bittorrent-client что мне не нужно передавать какие-либо параметры в createReadStream. Для этого нужно всего лишь несколько вариантов.