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

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

368
27 мая '10 в 21:35
источник поделиться
8 ответов

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

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

или более просто:

console.trace("Here I am!")
444
28 мая '10 в 23:45
источник

Связанные вопросы


Похожие вопросы

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

console.trace()
157
27 авг. '11 в 22:03
источник

Как уже было сказано, вы можете просто использовать команду trace:

console.trace("I am here");

Однако , если вы столкнулись с этим вопросом, чтобы узнать, как регистрировать трассировку стека исключений, вы можете просто зарегистрировать объект Exception.

try {  
  // if something unexpected
  throw new Error("Something unexpected has occurred.");     

} catch (e) {
  console.error(e);
}

Он будет записывать:

Ошибка: произошло что-то неожиданное.
      на main (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)
    в функции .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.

49
08 нояб. '15 в 14:32
источник

Чтобы напечатать 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)' ]
30
13 мая '15 в 13:56
источник

С легко доступным модулем Node можно получить полноэкранные трассировки стека из Node (хотя и с незначительным штрафом): http://www.mattinsler.com/post/26396305882/announcing-longjohn-long-stack-traces-for-node-js

6
02 сент. '12 в 5:52
источник

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

3
08 сент. '11 в 8:41
источник

Если вы хотите только регистрировать трассировку стека ошибки (а не сообщение об ошибке) 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)
2
18 июля '17 в 15:31
источник

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

0
18 авг. '16 в 1:11
источник

Посмотрите другие вопросы по меткам или Задайте вопрос