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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章