使用Meteor Server Side Route中的node-rio

时间:2015-01-27 04:00:17

标签: node.js meteor rserve

我正在尝试通过服务器端路由使用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})

2 个答案:

答案 0 :(得分:0)

两个错误:

  1. 正如您已经注意到的那样,rio希望将回调作为参数中回调字段的值,而不是直接在参数本身中。
  2. 您的结果(" 1")实际上并不是有效的JSON。
  3. 这有效:

    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));
    }
});