ФАТАЛЬНАЯ ОШИБКА: CALL_AND_RETRY_LAST Распределение не удалось - процесс исчерпал память - PullRequest
0 голосов
/ 05 февраля 2019

Для загрузки в виде файла CSV, я не знаю, в чем проблема, он работает нормально, когда пользователи 40000 записей, когда я пытаюсь попасть в API (80000 записей) процесс показа из памяти.пожалуйста, помогите мне с этим вопросом

  app.get('/excelData', function (req, result) {
 var fields = ['firstName','lastName','catalina_cardStatus','deviceType','appVerison','phoneNumber','emailAddress','language','state','lastLogin','dateOfBirth']
 var data = [];
   var status = true;
   User.find({accountType:'user',isDeleted: {$ne:{status}}}).sort({created: -1}).exec((err, res) => {
     var resultData = [];
         var len = res.length;
         res.map((user,key) =>{
       var resData = {};
       if(user) {
         resData.firstName = user.firstName;
         resData.lastName = user.lastName;
         resData.catalina_cardStatus = user.catalina_cardStatus;
         resData.language = user.language;
         resData.phoneNumber = user.phoneNumber;
         resData.deviceType = user.deviceType;
         resData.appVerison = user.appVerison;
         resData.emailAddress = user.emailAddress;
         resData.state = user.state;
         resData.dateOfBirth = user.dateOfBirth;
         if(user.lastLogin){
           var date = new Date(user.lastLogin);
           var utcDate = new Date(date.toISOString());
           var utc = utcDate.setHours(utcDate.getHours()-8);
           var usDate = utc;
             var time = moment(utc).format("DD-MM-YYYY");
             resData.lastLogin = time;
         }
 }
          resultData.push(resData);
          len--;
          if(len==0){
                var csv = json2csv({ data:resultData , fields: fields });
                fs.writeFile('path', csv, function(err,data) {
                  setTimeout(function () {
                      fs.unlinkSync('path'.csv');
                    }, 30000);
                    result.send({msg: "saved sucessfully",path :'path.csv'});
                  if (err)
                  {
                    throw err;
                    console.log("Error: "+err);
                  }
                })
          }

     })
 })

 });

1 Ответ

0 голосов
/ 05 февраля 2019

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

По умолчанию ограничение памяти в Node.js составляет 512 МБ, для решения этой проблемы вам необходимоувеличение лимита памяти используйте команду —- max-old-space-size. Можно избежать проблемы ограничения памяти.

node --max-old-space-size=1024 index.js #increase to 1gb
node --max-old-space-size=2048 index.js #increase to 2gb
node --max-old-space-size=3072 index.js #increase to 3gb
node --max-old-space-size=4096 index.js #increase to 4gb
node --max-old-space-size=5120 index.js #increase to 5gb
node --max-old-space-size=6144 index.js #increase to 6gb
node --max-old-space-size=7168 index.js #increase to 7gb
node --max-old-space-size=8192 index.js #increase to 8gb
...