Как распечатать трассировку стека в Node.js?

Кто-нибудь знает, как распечатать трассировку стека в Node.js?


person mike.toString    schedule 27.05.2010    source источник


Ответы (11)


Любой Error объект имеет stack член, который захватывает точку, в которой он был построен.

var stack = new Error().stack
console.log( stack )

или проще:

console.trace("Here I am!")
person isaacs    schedule 28.05.2010
comment
или просто sys.puts(new Error().stack) (после добавления системного модуля) - person sirhc; 09.08.2010
comment
На данный момент sys является устаревшей. Заменяется на 'util'. - person Pindatjuh; 14.04.2011
comment
+1 для отображения new Error().stack, который работает в тех случаях, когда вы не хотите задействовать консоль. - person Evgeniy Berezovsky; 31.07.2012
comment
Одним из преимуществ trace является то, что он также показывает текущую строку / контекст, чего не делает stack. Информация находится в объекте ошибки, если вы хотите вручную создать эту строку, я думаю. - person studgeek; 30.08.2012
comment
console.log (err.stack) и console.trace () не дают одинаковых результатов. В то время как err.stack дает вам трассировку стека для самого объекта err (функционирующего так, как мы все обычно думаем об исключениях), console.trace () распечатает стек вызовов в точке, где вызывается console.trace (). Поэтому, если вы поймаете ошибку, вызванную каким-то более глубоким уровнем кода, console.trace () не будет содержать код этого более глубокого уровня в трассировке стека, поскольку этого кода больше нет в стеке. Однако console.log (err.stack) будет содержать более глубокие слои до тех пор, пока он выбрасывает объект Error. - person d512; 21.02.2013

Теперь для этого есть специальная функция на консоли:

console.trace()
person Mariusz Nowak    schedule 27.08.2011
comment
Просто не забудьте прислушаться к приведенному выше комментарию о console.trace() . - person Qix - MONICA WAS MISTREATED; 14.09.2014
comment
По умолчанию будет отображаться только 10 кадров, вы можете использовать аргумент командной строки, чтобы увеличить это, например. --stack_trace_limit=200 - person Michael; 15.05.2016
comment
Что делать, если вы хотите вывести в файл журнала? - person Ya.; 02.12.2019
comment
Кажется, это не работает с обещаниями и async / await, не так ли? - person bluenote10; 05.04.2020

Как уже было сказано, вы можете просто использовать команду 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.

person Zanon    schedule 08.11.2015
comment
Не будет ли console.error(e) печатать все в объекте e, включая e.stack? - person drmrbrewer; 01.03.2017
comment
@drmrbrewer, спасибо, что указали на это. Похоже, что поведение Node в версиях 4.x и 7.x изменилось (вероятно, изменение V8). Я обновил свой ответ. - person Zanon; 01.03.2017
comment
@drmrbrewer подтвердил, что это поведение изменилось в версии 6.0.0. - person Zanon; 01.03.2017
comment
у вас есть ссылка на это очевидное изменение в поведении? Я все еще вижу (с узлом 6.9.4), что console.error(e) печатает только краткое сообщение. И я подозреваю, что это потому, что он печатает toString представление e, а toString для e возвращает только сообщение и ничего больше: developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/ - person drmrbrewer; 02.03.2017
comment
@drmrbrewer попробуйте установить n, чтобы протестировать различные версии Node на вашем компьютере или посмотреть этот тест с Node 7.4 и сравните его с Узел 0.8. Мне не удалось получить постоянную ссылку на последнюю, но запустил console.error(new Error("test")), чтобы увидеть разницу. Что касается упоминания об этом изменении в поведении, я не смог найти ни одного в журналах изменений узла. Кажется, это изменение V8, но я также не мог подтвердить. - person Zanon; 02.03.2017
comment
извините, я только что обнаружил кое-что важное. См. Мой комментарий к соответствующему сообщению: stackoverflow.com/questions/42528677/. Кажется, что регистрация ошибки сама по себе действительно показывает все содержимое ошибки, но попытка объединить ее (например, строку) с другим текстом приведет к использованию только части краткого сообщения. С осознанием этого все становится более осмысленным. - person drmrbrewer; 02.03.2017
comment
ты спасешь мой день) - person Alex; 14.07.2018

Чтобы распечатать 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)' ]
person ruX    schedule 13.05.2015

@isaacs ответ правильный, но если вам нужен более конкретный или более чистый стек ошибок, вы можете используйте эту функцию:

function getCleanerStack() {
   var err = new Error();
   Error.captureStackTrace(err, getStack);

   return err.stack;
}

Эта функция основана непосредственно на функции console.trace в NodeJS.

Исходный код: Последняя версия или Старая версия.

person Squidward Tentacles    schedule 18.06.2019
comment
он не работает, показывает стек только из текущей строки (а не из строки, в которой возникла эта ошибка). err.stack - более правильный ответ. - person Ian Zhong; 19.08.2019
comment
getStack не определен - person Druska; 04.02.2021

Попробуйте 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.

person Zheeeng    schedule 28.02.2018
comment
Если вы хотите, чтобы у ошибки было свойство stack, вам нужно вызвать это, если Node ›= 6: Error.captureStackTrace(error). - person cjbarth; 27.08.2018
comment
Обратите внимание: если вы не хотите, чтобы фрейм, вызвавший Error.captureStackTrace, отображался в трассировке стека, вы можете пропустить его, передав его как constructorOpt arg. - person Ullauri; 05.01.2019

Насколько я знаю, печать полной трассировки стека в nodejs невозможна, вы можете просто напечатать «частичную» трассировку стека, вы не можете увидеть, откуда вы пришли в код, только где возникает исключение. Это то, что Райан Даль объясняет в этом видео на YouTube. Для большей точности http://youtu.be/jo_B4LTHi3I минимум 56:30. Надеюсь это поможет

person ElHacker    schedule 08.09.2011
comment
правда, но модуль в ответе @Timboudreau исправляет это - person Bogdan D; 19.12.2014

Если кто-то все еще ищет это, как я, то есть модуль, который мы можем использовать, называемый «трассировка стека». Это действительно популярно. Ссылка на 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();
person Laszlo    schedule 04.07.2019

В 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

person Community    schedule 23.03.2021

Если вы хотите регистрировать только трассировку стека ошибки (а не сообщение об ошибке), Узел 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)
person GrayedFox    schedule 18.07.2017

вы можете использовать модуль node-stack-trace, который является мощным модулем для отслеживания стеков вызовов .

person Nitin9791    schedule 17.08.2016