Как напечатать трассировку стека в Node.js? - PullRequest
462 голосов
/ 27 мая 2010

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

Ответы [ 11 ]

544 голосов
/ 29 мая 2010

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

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

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

console.trace("Here I am!")
176 голосов
/ 27 августа 2011

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

console.trace()
80 голосов
/ 08 ноября 2015

Как уже ответили, вы можете просто использовать команду 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)
на объекте. (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 </strong>, регистрации объекта Exception будет недостаточно. В этом случае будет напечатано только:

[Ошибка: произошло нечто неожиданное.]

Для версии узла <6, используйте <code>console.error(e.stack) вместо console.error(e), чтобы напечатать сообщение об ошибке плюс полный стек, как в текущей версии узла.


Примечание: если исключение создается в виде строки, такой как throw "myException", получить трассировку стека и ведение журнала невозможно e.stack приводит к undefined .

Чтобы быть в безопасности, вы можете использовать

console.error(e.stack || e);

и он будет работать для старых и новых версий Node.js.

35 голосов
/ 13 мая 2015

Чтобы распечатать трассировку стека 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)' ]
9 голосов
/ 02 сентября 2012

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

3 голосов
/ 28 февраля 2018

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

3 голосов
/ 08 сентября 2011

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

2 голосов
/ 18 июля 2017

Если вы хотите регистрировать только трассировку стека ошибки (а не сообщения об ошибке), узел 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)
1 голос
/ 18 июня 2019

@ isaacs ответ правильный, но у меня есть более правильный ответ. Этот ответ основан на оригинальном исходном коде класса Console на узле js ( исходный код ):

function getStack() {
  var err = new Error();

  Error.captureStackTrace(err, getStack);

  return err.stack;
}
0 голосов
/ 04 июля 2019

Если кто-то все еще ищет это, как я, то есть модуль, который мы можем использовать, называемый «trace-trace». Это действительно популярно. NPM Link

Тогда иди по следу.

  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();
...