我想使用node --debug app.js
运行以下脚本,并让节点等待远程调试会话开始。我认为app.js
脚本在调试器建立连接之前崩溃了。我正在使用隧道将端口5858转发到无业游民的盒子,并且我知道该部件正在工作,因为我之前已经成功使用了完全相同的设置。
这可能吗?代码在afterCheck(err,spam)) //spam is not defined
崩溃,我想弄清楚原因。
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : '123',
database : 'kommunity',
debug: ['ComQueryPacket']
});
var akismet = require('akismet').client({ blog: 'deleted', apiKey: 'deleted' });
var selectPosts = "SELECT p.id as id, poster_ip, message, p.poster FROM topics t\
LEFT JOIN posts p on t.first_post_id = p.id WHERE poster_ip != ''";
//var spam = false;
akismet.verifyKey(function(err, verified) {
if(err) throw err;
if (verified) {
console.log('API key successfully verified.');
connection.connect();
connection.query(selectPosts, function(err, rows, fields) {
if (err) throw err;
var count = 0;
rows.forEach( function(entry) {
//console.log('foreach called with count '+count);
count++;
//console.log(entry['id']);
akismet.checkSpam({
user_ip: entry['poster_ip'],
comment_author: entry['poster'],
comment_content: entry['message']
}, afterCheck(err,spam))
});
});
}
else {
console.log('Unable to verify API key.');
}
});
var afterDelete = function (err, rows, fields) {
if (err) throw err;
console.log('deleted topic '+rows[0]);
console.log('spam');
connection.end();
}
var afterCheck = function(err, spam, entry) {
if(err) throw err;
console.log('after check called and spam is :'+spam);
var deleteQuery = "DELETE FROM topics , posts USING topics INNER JOIN posts \
WHERE topics.id=posts.topic_id AND topics.id ="
if(spam) {
console.log('spam');
console.log('entry is ' + entry);
connection.query(deleteQuery + entry.id + ';', afterDelete(err, rows, fields) );
connection.end();
} else {
console.log('Not spam');
}
}
来自Webstorm Run/Debug Help。我知道这是因为在Webstorm中调试了我的nodejs应用程序。
使用--debug-brk选项,应用程序的执行将暂停发射之后。该选项允许您调试执行的代码在开始。
使用--debug选项,必须在以下位置执行代码执行应用程序启动,然后应用程序等待调试器连接到它。当您不在时,此选项很有用现在要调试Node.js,但您想稍后对其进行调试。
2020年5月更新
[对于节点和npm版本--node 10.16.0 --npm 6.9.0,-debug-brk选项会提供弃用警告。
(node:1601) [DEP0062] DeprecationWarning: `node --debug` and `node --debug-brk` are invalid. Please use `node --inspect` or `node --inspect-brk` instead.
我们应该为此目的使用--inspect和--inspect-brk。