我正在尝试通过服务器端路由使用Meteor访问Rserve服务器以调用R代码。允许访问Rserve的Node.js模块是node-rio我已使用meteorhacks:npm Meteor包中的Async.wrap函数来包装“evaluate”方法。当我尝试在浏览器中访问路径路径“/ rio”时,我将“1”写入控制台日志,这对于评估R中的命令“1”是正确的,但Chrome挂起时显示“正在等待”对于localhost“。它不会进入下一行,并且永远不会显示“结果:1”。消息“net :: ERR_EMPTY_RESPONSE最终会显示在Chrome中。
Router.route('/rio', function() {
var rio = Meteor.npmRequire('rio');
var evalSync = Async.wrap(rio, 'evaluate');
var result = evalSync('1');
console.log("Result: " + result);
// JSON
this.response.writeHead(200, {'Content-Type': 'application/json'});
this.response.end(result);
}, {
where: 'server'
});
“evaluate”有一个回调函数参数,但它包含在options参数中并被访问:
rio.evaluate(R_COMMAND, {callback: CALLBACK_FUNCTION})
答案 0 :(得分:0)
两个错误:
这有效:
Router.route('/rio', function() {
var rio = Meteor.npmRequire('rio');
var evalSync = Async.wrap(function(exp, callback) {
rio.evaluate(exp, {callback: callback});
});
var result = evalSync('1');
console.log("Result: " + result);
// JSON
this.response.writeHead(200, {'Content-Type': 'application/json'});
this.response.end(JSON.stringify({result: result}));
}, {
where: 'server'
});
答案 1 :(得分:0)
此答案将产生' packageVersion(" base")'的预期结果,它使用节点模块rserve-client代替rio连接到Rserve。该路线还处理参数' pkg'。这是StackOverflow问题,它指出了我正确的方向:
How to call async method from Meteor own callbacks?
Router.route('rserve', {
path: '/rserve/:pkg',
where: 'server',
action: function() {
var r = Meteor.npmRequire("rserve-client");
var Future = Meteor.npmRequire("fibers/future");
var fut = new Future();
var cmd = 'packageVersion("' + this.params.pkg + '")';
var callR = function (input) {
r.connect('127.0.0.1', 6311, function (err, client) {
client.evaluate(input, function (err, ans) {
console.log("Result: " + ans);
client.end();
fut.return(ans);
});
});
return fut.wait();
};
var result = callR(cmd);
this.response.writeHead(200, {'Content-Type': 'application/json'});
this.response.end(JSON.stringify(result));
}
});