Кто-нибудь знает, как печатать трассировку стека в Node.js?
Как распечатать трассировку стека в Node.js?
Ответ 1
Любой объект Error
имеет член stack
, который перемещает точку, в которой он был сконструирован.
var stack = new Error().stack
console.log( stack )
или более просто:
console.trace("Here I am!")
Ответ 2
Теперь на консоли есть выделенная функция:
console.trace()
Ответ 3
Как уже ответили, вы можете просто использовать команду трассировки:
console.trace("I am here");
Однако, если вы пришли к этому вопросу, пытаясь найти способ регистрации трассировки стека исключения, вы можете просто зарегистрировать объект Exception.
try {
// if something unexpected
throw new Error("Something unexpected has occurred.");
} catch (e) {
console.error(e);
}
Это войдет:
Ошибка: произошло нечто неожиданное.
в основном (c:\Users\Me\Documents\MyApp\app.js: 9: 15)
на объекте. (C:\Users\Me\Documents\MyApp\app.js: 17: 1)
в Module._compile (module.js: 460: 26)
в Object.Module._extensions..js(module.js: 478: 10)
в Module.load(module.js: 355: 32)
в Function.Module._load (module.js: 310: 12)
в Function.Module.runMain(module.js: 501:10)
при запуске (node.js: 129: 16)
в node.js: 814: 3
Если ваша версия Node.js <6.0.0, регистрации объекта Exception будет недостаточно. В этом случае он будет печатать только:
[Ошибка: произошло нечто неожиданное.]
Для версии узла <6 используйте console.error(e.stack)
вместо console.error(e)
чтобы напечатать сообщение об ошибке плюс полный стек, как в текущей версии Node.
Примечание: если исключение создается в виде строки, например throw "myException"
, невозможно получить трассировку стека и e.stack
журнал. e.stack
приводит к неопределенности.
Чтобы быть в безопасности, вы можете использовать
console.error(e.stack || e);
и это будет работать для старых и новых версий Node.js.
Ответ 4
Чтобы напечатать stacktrace Error
в консоли более читаемым способом:
console.log(ex, ex.stack.split("\n"));
Результат:
[Error] [ 'Error',
' at repl:1:7',
' at REPLServer.self.eval (repl.js:110:21)',
' at Interface.<anonymous> (repl.js:239:12)',
' at Interface.EventEmitter.emit (events.js:95:17)',
' at Interface._onLine (readline.js:202:10)',
' at Interface._line (readline.js:531:8)',
' at Interface._ttyWrite (readline.js:760:14)',
' at ReadStream.onkeypress (readline.js:99:10)',
' at ReadStream.EventEmitter.emit (events.js:98:17)',
' at emitKey (readline.js:1095:12)' ]
Ответ 5
С легко доступным модулем Node можно получить полноэкранные трассировки стека из Node (хотя и с незначительным штрафом): http://www.mattinsler.com/post/26396305882/announcing-longjohn-long-stack-traces-for-node-js
Ответ 6
Для того, что я знаю, печать полной трассировки стека в nodejs невозможна, вы можете просто распечатать "частичную" трассировку стека, вы не можете видеть, откуда вы пришли в коде, где происходит Исключение. Это то, что Райан Дал объясняет в этом видео на YouTube. http://youtu.be/jo_B4LTHi3I в минуту 56:30 за точный. Надеюсь, что это поможет
Ответ 7
Попробуйте Error.captureStackTrace(targetObject [, constructorOpt]).
const myObj = {};
function c() {
// pass
}
function b() {
Error.captureStackTrace(myObj)
c()
}
function a() {
b()
}
a()
console.log(myObj.stack)
Функции a
и b
записываются в стек ошибок и сохраняются в myObj
.
Ответ 8
Если вы хотите только регистрировать трассировку стека ошибки (а не сообщение об ошибке) Node 6 и выше, автоматически включает имя ошибки и сообщение внутри трассировки стека, что немного раздражает, если вы хотите сделать это некоторые пользовательские обработки ошибок:
console.log(error.stack.replace(error.message, ''))
В этом обходном пути будет записано только имя ошибки и трассировка стека (так что вы можете, например, отформатировать сообщение об ошибке и отобразить его как хотите в другом месте в вашем коде).
В приведенном выше примере будет отображаться только имя ошибки, следуя трассировке стека, например:
Error:
at /Users/cfisher/Git/squashed/execProcess.js:6:17
at ChildProcess.exithandler (child_process.js:213:5)
at emitTwo (events.js:106:13)
at ChildProcess.emit (events.js:191:7)
at maybeClose (internal/child_process.js:877:16)
at Socket.<anonymous> (internal/child_process.js:334:11)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
at Pipe._handle.close [as _onclose] (net.js:498:12)
Вместо:
Error: Error: Command failed: sh ./commands/getBranchCommitCount.sh HEAD
git: 'rev-lists' is not a git command. See 'git --help'.
Did you mean this?
rev-list
at /Users/cfisher/Git/squashed/execProcess.js:6:17
at ChildProcess.exithandler (child_process.js:213:5)
at emitTwo (events.js:106:13)
at ChildProcess.emit (events.js:191:7)
at maybeClose (internal/child_process.js:877:16)
at Socket.<anonymous> (internal/child_process.js:334:11)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
at Pipe._handle.close [as _onclose] (net.js:498:12)
Ответ 9
@isaacs ответ правильный, но у меня есть более правильный ответ. Этот ответ основан на оригинальном исходном коде класса Console на узле js (исходный код):
function getStack() {
var err = new Error();
Error.captureStackTrace(err, getStack);
return err.stack;
}
Ответ 10
вы можете использовать node-stack-trace модуль, который является полнофункциональным модулем для отслеживания стеков вызовов.
Ответ 11
В случае, если кто-то все еще ищет это, как я, то есть модуль, который мы можем использовать, называемый "трассировка стека". Это действительно популярно. НПМ Ссылка
Затем идите по следу.
var stackTrace = require('stack-trace');
.
.
.
var trace = stackTrace.get();
trace.map(function (item){
console.log(new Date().toUTCString() + ' : ' + item.toString() );
});
Или просто напечатайте след:
var stackTrace = require('stack-trace');
.
.
.
var trace = stackTrace.get();
trace.toString();