2016-08-12 4 views
1

同時に100個以上のファイルをダウンロードしようとしています。しかし、ダウンロード機能を実行すると、Macbookがフリーズ(新しいタスクを実行することができない)し、Windowsではダウンロードも(フリーズしません)、どちらの場合でもダウンロードが進行しません(アイドルネットワーク)。ここでNode.JSは何百ものファイルを同時にダウンロードします

は、私のダウンロードモジュールです:

var express = require('express'); 
var router = express.Router(); 
var fs = require('fs'); 
var youtubedl = require('youtube-dl'); 
var links = require('../models/Links'); 

router.get('/', function (req, res, next) { 
    links.find({dlStatus: false}, function (err, docs) { 

     if (err) { 
      console.log(err); 
      res.end(); 
     } else if (!docs) { 
      console.log('No incomplete downloads!'); 
      res.end(); 
     } else { 
      for (var i = 0; i < docs.length; i++) { 

       //todo scraping 


       var video = youtubedl(docs[i].url, [], {cwd: __dirname}); 

       // Will be called when the download starts. 
       video.on('info', function (info) { 
        console.log('Download started'); 
        console.log(info); 
       }); 

       video.pipe(fs.createWriteStream('./downloads/' + docs[i].id + '-' + i + '.mp4')); 
       video.on('complete', function complete(info) { 
        links.findOneAndUpdate({url: info.webpage_url}, {dlStatus: true}, function (err, doc) { 
         if (err)console.log(err); 
         else console.log('Download completed!') 
        }); 
       }); 
      } 
     } 
    }); 
}); 

module.exports = router; 

は今、誰もがここで私を助けてくださいことができますか?私はファイルをダウンロードするためにthisモジュールを使用しています。

+1

シングルはダウンロードしていますか? – vkstack

+0

はい、私は同時に5つのダウンロードを試みました、それもあまりにも、今私は101でしようとしていますこれは起こる –

+0

async.Thatを使用してみてください – vkstack

答えて

2

この場合、ソリューションはasyncを使用しています。

async.each()

var express = require('express'); 
var router = express.Router(); 
var fs = require('fs'); 
var youtubedl = require('youtube-dl'); 
var links = require('../models/Links'); 
var async = require('async') 

router.get('/', function (req, res, next) { 
    links.find({dlStatus: false}, function (err, docs) { 

     if (err) { 
      console.log(err); 
      res.end(); 
     } else if (!docs) { 
      console.log('No incomplete downloads!'); 
      res.end(); 
     } else { 
      async.each(docs,function(doc,cb){ 
       var video = youtubedl(doc.url, [], {cwd: __dirname}); 

       // Will be called when the download starts. 
       video.on('info', function (info) { 
        console.log('Download started'); 
        console.log(info); 
       }); 

       video.pipe(fs.createWriteStream('./downloads/' + docs.id + '-' + i + '.mp4')); 
       video.on('complete', function complete(info) { 
        links.findOneAndUpdate({url: info.webpage_url}, {dlStatus: true}, function (err, doc) { 
         if (err){ 
         console.log(err); 
         cb(err); 
         } 
         else { 
         console.log('Download completed!'); 
         cb() 
         } 
        }); 
       }); 

      },function(err){ 
       if(err) 
       return console.log(err); 
       console.log("Every thing is done,Here!!"); 
      }) 
     } 
    }); 
}); 

module.exports = router; 

そして、あなたはあまりにもasync.eachLimits()を使用してバッチですべてのものを処理することができて....このようにそれを試してみてください。

+0

ありがとう、私はエラーを処理することを忘れました。両方のコードが正常に動作しています:) –

関連する問題