Contextify:如何捕获异步错误

时间:2014-09-30 07:53:19

标签: node.js contextify

我需要在节点中运行不安全的JS脚本,并能够从错误中恢复。 该脚本可以使用异步函数,因此我使用contextify而不是VM模块中内置的节点。 问题是脚本中异步代码中的错误导致节点进程崩溃。

这是我的测试:

var contextify = require('contextify');
var context = {
    console:{
        log:function(msg){
            console.log('Contextify : '+msg);
        }
    },
    setTimeout:setTimeout
};
console.log("begin test");
contextify(context);
try{ // try to run unsafe script
    //context.run("console.log('Sync user script error');nonExistingFunction();"); // works
    context.run("setTimeout(function(){ console.log('Async user script error');nonExistingFunction(); },2000);"); // crash node process
}catch(err){
    console.log("Recover sync user script error"); 
}
console.log("end test");

如何捕获异步错误?

1 个答案:

答案 0 :(得分:0)

我通过使用child_process为脚本创建一个线程来解决问题:

// main.js

var child_process = require('child_process');

var script = child_process.fork("scriptrunner.js");
script.on('error',function(err){
    console.log("Thread module error " + JSON.stringify(err));
});
script.on('exit',function(code,signal){
    if(code==null)
        console.log("Script crashed");
    else console.log("Script exited normally");
});
script.send("setTimeout(function(){ console.log('Async user script error');nonExistingFunction(); },2000);");

// scriptrunner.js

var contextify = require('contextify');

var context = {
    console:{
        log:function(msg){
            console.log('Contextify : '+msg);
        }
    },
    setTimeout:setTimeout
};
contextify(context);

process.on('message', function(js) {            
    try{        
        context.run(js);
    }catch(err){
        console.log("Catch sync user script error " + err);
    }
});

现在,如果脚本崩溃,它会崩溃自己的进程而不是主节点进程。缺点是我不能在我的主进程和脚本的线程之间传递复杂对象(例如我的上下文),我需要找到一个解决方法。