nodejs开发中如何调试基于多进程的程序


在nodejs开发中,通过child_process启动多进程时,能够在启动的同时直接启动不同的调试端口:这段程序是从5588自增1为每个进程都设置了唯一的端口:

var globalI = 0;
var DEBUG_BRK = '--debug-brk',
IS_DEBUGGING = isDebugging();

function isDebugging() {
var execArg, port;
for (var i = 0; i < process.execArgv.length; i++) {
execArg = process.execArgv[i];
var debugBrkWithPort = DEBUG_BRK + '=';
if (execArg.indexOf(debugBrkWithPort) === 0) {
port = parseInt(execArg.substring(debugBrkWithPort.length));
if (!isNaN(port)) {
return true;
}
}
}
return false;
}
function addDebugParameter(args) {
if (IS_DEBUGGING) {
globalI++;
args.splice(0, 0, DEBUG_BRK +"="+ (5588+globalI));
}
};

在fork的同时调用 :

var processParameters = [path];
addDebugParameter(processParameters);
var sub=require('child_process').fork(path, obj.bindings[name].args, {
'cwd' : process.cwd(),
'env' : env,
execArgv:processParameters
});

注意:

1.如果使用以上方法出现websotrm调试时,仍然不进入断点,webstorm在启动调试后不继续的情况,请把webstorm中的node的路径换成以下内容的sh文件 [同时安装socat],社区中说是webstorm的一个bug。


ORIG_PORT=`echo $* | sed 's/.*--debug-brk=\([0-9]*\).*/\\1/'`
NEW_PORT=`expr $$ "%" 64000 + 1024`

ARGS=`echo $* | sed "s/--debug-brk=[0-9]*/--debug-brk=$NEW_PORT/"`

node $ARGS &
if ["$ORIG_PORT" -lt ""];then
node $ARGS &
else
node
fi

sleep 1

if ["$ORIG_PORT" -lt ""];then
socat TCP4-LISTEN:$ORIG_PORT,fork,bind=127.0.0.1 TCP:localhost:$NEW_PORT
else
socat TCP4-LISTEN:$ORIG_PORT,fork,bind=127.0.0.1 TCP:localhost:$NEW_PORT
fi

2.如果使用chrome进行调试,请更换DEBUG_BRK

你可能感兴趣的:(nodejs,调试)