Кто-нибудь знает, как распечатать трассировку стека в Node.js?
Как распечатать трассировку стека в Node.js?
Ответы (11)
Любой Error
объект имеет stack
член, который захватывает точку, в которой он был построен.
var stack = new Error().stack
console.log( stack )
или проще:
console.trace("Here I am!")
sys.puts(new Error().stack)
(после добавления системного модуля)
- person sirhc; 09.08.2010
'util'
.
- person Pindatjuh; 14.04.2011
new Error().stack
, который работает в тех случаях, когда вы не хотите задействовать консоль.
- person Evgeniy Berezovsky; 31.07.2012
trace
является то, что он также показывает текущую строку / контекст, чего не делает stack
. Информация находится в объекте ошибки, если вы хотите вручную создать эту строку, я думаю.
- person studgeek; 30.08.2012
Теперь для этого есть специальная функция на консоли:
console.trace()
console.trace()
.
- person Qix - MONICA WAS MISTREATED; 14.09.2014
--stack_trace_limit=200
- person Michael; 15.05.2016
Как уже было сказано, вы можете просто использовать команду trace:
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)
в Object. (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 будет недостаточно. В этом случае он будет печатать только:
[Ошибка: произошло что-то непредвиденное.]
Для Node версии ‹6 используйте console.error(e.stack)
вместо console.error(e)
, чтобы распечатать сообщение об ошибке плюс полный стек, как это делает текущая версия Node.
Примечание. если исключение создается в виде строки типа throw "myException"
, получить трассировку стека невозможно, и e.stack
ведение журнала дает undefined.
Чтобы быть в безопасности, вы можете использовать
console.error(e.stack || e);
и он будет работать для старых и новых версий Node.js.
console.error(e)
печатать все в объекте e
, включая e.stack
?
- person drmrbrewer; 01.03.2017
6.9.4
), что console.error(e)
печатает только краткое сообщение. И я подозреваю, что это потому, что он печатает toString
представление e
, а toString
для e
возвращает только сообщение и ничего больше: developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/
- person drmrbrewer; 02.03.2017
console.error(new Error("test"))
, чтобы увидеть разницу. Что касается упоминания об этом изменении в поведении, я не смог найти ни одного в журналах изменений узла. Кажется, это изменение V8, но я также не мог подтвердить.
- person Zanon; 02.03.2017
Чтобы распечатать 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)' ]
@isaacs ответ правильный, но если вам нужен более конкретный или более чистый стек ошибок, вы можете используйте эту функцию:
function getCleanerStack() {
var err = new Error();
Error.captureStackTrace(err, getStack);
return err.stack;
}
Эта функция основана непосредственно на функции console.trace
в NodeJS.
Исходный код: Последняя версия или Старая версия.
err.stack
- более правильный ответ.
- person Ian Zhong; 19.08.2019
Попробуйте 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
.
stack
, вам нужно вызвать это, если Node ›= 6: Error.captureStackTrace(error)
.
- person cjbarth; 27.08.2018
Error.captureStackTrace
, отображался в трассировке стека, вы можете пропустить его, передав его как constructorOpt
arg.
- person Ullauri; 05.01.2019
Насколько я знаю, печать полной трассировки стека в nodejs невозможна, вы можете просто напечатать «частичную» трассировку стека, вы не можете увидеть, откуда вы пришли в код, только где возникает исключение. Это то, что Райан Даль объясняет в этом видео на YouTube. Для большей точности http://youtu.be/jo_B4LTHi3I минимум 56:30. Надеюсь это поможет
Если кто-то все еще ищет это, как я, то есть модуль, который мы можем использовать, называемый «трассировка стека». Это действительно популярно. Ссылка на NPM
Затем пройдите по следу.
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();
В v15.12.0 для этого есть разные методы,
1. console.trace(anything)
2. Error.captureStackTrace(Object)
3. console.log(new Error().stack)
4. Try Catch - Use console.log(e), where `e` is catched by catch block
ИЛИ еще лучше используйте stacktracejs в любом коде Javascript
Если вы хотите регистрировать только трассировку стека ошибки (а не сообщение об ошибке), Узел 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)
вы можете использовать модуль node-stack-trace, который является мощным модулем для отслеживания стеков вызовов .