nodejs開發(fā)中如何調(diào)試基于多進(jìn)程的程序
在nodejs開發(fā)中,通過child_process啟動多進(jìn)程時,能夠在啟動的同時直接啟動不同的調(diào)試端口:這段程序是從5588自增1為每個進(jìn)程都設(shè)置了唯一的端口:
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的同時調(diào)用 :
var processParameters = [path];
addDebugParameter(processParameters);
var sub=require('child_process').fork(path, obj.bindings[name].args, {
'cwd' : process.cwd(),
'env' : env,
execArgv:processParameters
});
注意:
1.如果使用以上方法出現(xiàn)websotrm調(diào)試時,仍然不進(jìn)入斷點,webstorm在啟動調(diào)試后不繼續(xù)的情況,請把webstorm中的node的路徑換成以下內(nèi)容的sh文件 [同時安裝socat],社區(qū)中說是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進(jìn)行調(diào)試,請更換DEBUG_BRK

浙公網(wǎng)安備 33010602011771號