我正在尝试使用Node.js编写MongoDB map / reduce作业。我有调用map reduce的node.js代码正常工作,但我需要在mapper方法中调用Node.js。看起来它将mapper(和reducer)解释为Javascript,而不是Node.js.
有没有办法像Node.js一样执行mapper和reducer?我可以通过Javascript调用我的Node.js吗?
我的代码:
var mongo = require('mongodb'),
Server = mongo.Server,
Db = mongo.Db;
var fbFeed = require('./getFeeds');
var server = new Server('localhost', 27017, {auto_reconnect: true});
var db = new Db('test', server);
var map = function () {
fbFeed.getFbFeed(this.dbId, function(record) {
emit(record.fbId, record);
});
}
var reduce = function (key, values) {
return values;
}
db.open(function (err, db) {
if (!err) {
db.collection('facebookToScan', function (err, collection) {
if (!err) {
collection.mapReduce(map, reduce, {'out': "fbClicks"}, function(err, collection) {
});
}
});
}
});
(其中'./getFeeds'包含getFbFeed
)
我的错误是:
mr failed, removing collection :: caused by :: 9014 map invoke failed: JS Error: ReferenceError: fbFeed is not defined nofile_b:1
答案 0 :(得分:1)
我不知道这是可能的。 MongoDB中的M / R在其自己的JavaScript环境中运行,将链接到node.js运行的JavaScript环境。