안녕하세요, Node.js를 : 점점 async.map 느린
나는 MongoDB를 데이터베이스에 데이터를 저장하기위한 API를 제공하기 위해 Node.js를 사용합니다.read
메서드에서 여러 테스트를 실행했습니다.이 테스트에서는 ID를 사용하고 해당 문서를 반환합니다. 요점은이 문서를 지정된 순서대로 반환해야한다는 것입니다. 이를 보장하기 위해 다음 코드를 사용합니다.
// Sequentially fetch every element
function read(ids, callback) {
var i = 0;
var results = [];
function next() {
db.findOne(ids[i], function (err, doc) {
results.push(err ? null : doc);
if (ids.length > ++i) {
return next();
}
callback(results);
});
}
next();
}
이렇게하면 올바른 순서로 문서를 하나씩 가져옵니다. 27k 문서를 검색하려면 노트북에서 약 11 초가 걸립니다. 나는 27K 문서는 간단한 코드를 사용하여 8 초 만에 검색 한 것을보고 매우 만족, 단일 테스트를 실행 한 후
// Asynchronously map the whole array
var async = require('async');
function read(ids, callback) {
async.map(ids, db.findOne.bind(db), callback):
}
:
그러나, 나는이 방법을 개선 할 수있다라고 생각했습니다.
동일한 요청을 반복하면 문제가 발생합니다. 응답 시간은 계속 증가합니다 (검색된 요소 수에 비례하여) : 9s 10s 11s 12s...
. 이 문제는 순차 버전에서는 발생하지 않습니다.
두 버전의 Node.js, v6.2.0 및 v0.10.29를 사용해 보았습니다. 문제는 동일합니다. 이 대기 시간의 원인은 무엇이며 어떻게 억제 할 수 있습니까?
왜 '찾기'를 사용하지 않습니까? –
여기를 참조하십시오 : http://stackoverflow.com/questions/8303900/mongodb-mongoose-findmany-find-all-documents-with-ids-listed-in-array –
'async.mapLimit'을 사용하여 과부하를 방지하십시오. 그러나'find ({_ id : {$ in : list}})'는 여러 번이 아니라 단일 데이터베이스 요청 때문에 항상 더 좋습니다. –