【发布时间】:2013-09-16 04:44:47
【问题描述】:
作为自学更多关于节点 js 的练习,我开始使用 aws-sdk 为 SimpleDB (sdb) 制作一个基本的 CRUD REST 服务器。
在我使用读取域的函数之前,一切都运行得很顺利。为此,aws-sdk 有两个函数:listDomains 和 domainMetadata。 listDomains 返回一个 sdb 域名数组。 domainMetadata 将返回有关域的其他统计信息,但一次仅返回一个域的统计信息。结果中不包含域名。
我的脚本正在运行 listDomains 并在 JSON 响应中返回一个数组就好了。我想让我的 api readDomains 函数更加雄心勃勃,并让它在同一个 api 调用中返回所有域的元数据。毕竟,同时运行少量的 domainMetadata 调用是 node 的异步 io 应该发挥作用的地方。
问题是我不知道如何运行可变数量的调用,对所有调用使用相同的回调,将每个 domainMetadata 调用的结果与它的 domainName 匹配(因为它是异步的并且不能保证按请求的顺序返回)并告知所有元数据请求何时完成,以便我可以发送最终响应。将我的问题区域放入代码中:
domain.receiveDomainList = function(err, data){
var domainList = [];
for(var i=0; i<data.DomainNames.length; i++){
sdb.domainMetaData({"DomainName":data.DomainNames[i]},domain.receiveMetadata);
// alternatively: domainList.push({"DomainName":data.DomainNames[i]});
}
// alternatively:
// async.map(domainList, sdb.domainMetadata, domain.receiveMetadata)
console.log(domainList);
}
domain.receiveMetadata = function (err, data){
// I figure I can stash the results one at a time in an array in the
// parent scope but...
// How can I tell when all of the results have been received?
// Since the domainname used for the original call is not returned with
// the results how do I tell what result matches what request?
}
根据我对 async 的自述文件的阅读,map 函数至少应该通过一些黑魔法将元数据响应与请求匹配,但它会导致节点在 aws 同步库中爆炸,并出现错误“没有方法”makeRequest '"。
有没有什么办法让一切都得到:请求并行运行,请求与响应相匹配,并知道我何时收到了所有信息?
【问题讨论】:
-
查看 promise 或 async.js 库
-
Q 和其他承诺连续运行,所以我失去了节点异步设置的巨大好处。我尝试了 async.map 没有运气。正如我所提到的,它导致 aws-sdk 出现错误。 async.parallel 需要使用静态函数调用编写,因此不适用于可变数量的调用。如果我错了,您能否在这种情况下提供一个可行的示例调用?
-
您可以创建许多并行运行的 Promise,然后使用
Q.all等待它们的结果。对于Q.all和async.parallel,您可以传递具有任意数量任务的数组。
标签: javascript node.js amazon-web-services express