У меня есть некоторый код, очень похожий на пример в документации по кластеру, по адресу http://nodejs.org/docs/v0.6.0/api/cluster.html,:
var cluster = require('cluster');
var server = require('./mycustomserver');
var numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
var i;
// Master process
for (i = 0; i < numCPUs; i++) {
cluster.fork();
}
cluster.on('death', function (worker) {
console.log('Worker ' + worker.pid + ' died');
});
} else {
// Worker process
server.createServer({port: 80}, function(err, result) {
if (err) {
throw err;
} else {
console.log('Thread listening on port ' + result.port);
}
});
}
Я установил инспектор узлов и попытался использовать и его, и плагин Eclipse V8, подробно описанный в https://github.com/joyent/node/wiki/Using-Eclipse-as-Node-Applications-Debugger, для отладки моего приложения, но похоже, что я не могу подключить отладчик к разветвленным экземплярам кластера, чтобы поставить точки останова на интересную логику сервера - я могу отлаживать только ту часть приложения, которая порождает процессы кластера. Кто-нибудь знает, могу ли я на самом деле сделать такую вещь, или мне придется провести рефакторинг моего приложения, чтобы использовать только один поток в режиме отладки?
Я новичок на Node.js, так что я надеюсь, что что-то очевидное мне не хватает здесь.