我可能有点新了解承诺esp蓝鸟的基本功能。我试图完成的是一个处理批量写入250K +行到数据库的API服务器。大约需要30秒才能完成请求。我希望API服务器根据批量写入的成功返回正常或错误。当我不使用承诺时,我没有机会冒出错误,因为请求没有等待批量写入完成。但是,如果我使用承诺错误和成功正常工作。但是,直到操作完成后,服务器才会响应。简而言之,使用promise库来处理批量写入会阻塞API服务器。蓝鸟承诺阻止自然
function chunk(arr, chunkSize) {
var R = [];
for (var i=0,len=arr.length; i<len; i+=chunkSize)
{
R.push(arr.slice(i,i+chunkSize));
}
return promise.resolve(R);
}
exports.add = function(req, res) {
var PO_STD_LT_TIME = 90; //DAYS
Parts.sync()
.then(function() {
return Parts.destroy({
where: {}
});
})
.then(function() {
var workbook = XLSX.readFileSync(__dirname + '/dbo_tblCPLParts_.xlsx');
var sheet_name_list = workbook.SheetNames;
var JSON_S = XLSX.utils.sheet_to_json(workbook.Sheets[sheet_name_list[0]]);
var size = 40000;
chunk(JSON_S, size).then(function(JSON_Small) {
promise.each(JSON_Small, function (JSON_small_){
Parts.bulkCreate(JSON_small_)
.catch(function(err) {
res.json(500, {
Error: "Error : " + err
});
})
}).finally(ext_fns.handleResult(res,200))
})
})
}
处理这个问题的最好方法是什么?我是否以正确的方式使用承诺?
所有js都阻塞(setTimeout/interval除外)。只有主持人可以提供休息的机会 – dandavis
假设任务总是花费30秒完成,但在promisifying之前,你没有意识到。 –