我有一个 MapReduce 作业,我只想在辅助服务器上运行。MapReduce 输出将创建一个临时集合来存储结果,我想从该集合中读取结果,然后删除该集合。
问问题
231 次
2 回答
0
上面的答案是准确的。仅提及其他信息:
- Map-Reduce(和聚合管道作业)必须是只读的(从数据库的角度来看)才能在辅助节点上运行。
- 对于 MR,需要传递设置
inline
参数outline
。
示例(来源):
RS-replica-0:PRIMARY> db.txns.findOne()
{
"_id" : ObjectId("584a3b71cdc1cb061957289b"),
"custid" : "cust_66",
"txnval" : 100,
"items" : [{"sku": sku1", "qty": 1, "pr": 100}, ...],
...
}
RS-replica-0:PRIMARY> var mapFunc = function() { emit(this.custid, this.txnval); }
RS-replica-0:PRIMARY> var reduceFunc = function(key, values) { return Array.sum(values); }
RS-replica-0:PRIMARY> db.txns.mapReduce(mapFunc, reduceFunc, {out: { inline: 1 }})
{
"results" : [
{
"_id" : "cust_0",
"value" : 72734
},
{
"_id" : "cust_1",
"value" : 67737
},
...
]
"timeMillis" : 215,
"counts" : {
"input" : 10000,
"emit" : 10000,
"reduce" : 909,
"output" : 101
},
"ok" : 1
}
于 2017-01-30T07:36:12.973 回答