web-dev-qa-db-ja.com

Node.jsでスタックレースを印刷する方法

Node.jsでスタックトレースを印刷する方法を知っている人はいますか?

460
mike.toString

どのErrorオブジェクトにも、それが構築された時点をトラップするstackメンバーがあります。

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

もっと簡単に言うと:

console.trace("Here I am!")
541
isaacs

そのために、コンソールに 専用の関数があります

console.trace()
176
Mariusz Nowak

すでに答えたように、あなたは単純に 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)
at 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)を使用します。


注:例外がthrow "myException"のような文字列として作成された場合、スタックトレースを取得してe.stackをロギングすることはできません未定義

安全のために、あなたは使うことができます

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

そしてそれは新旧のNode.jsバージョンでも動作します。

80
Zanon

コンソールで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)' ]
35
ruX

すぐに利用できるNodeモジュールを使えば、Nodeから全長スタックトレースを取得することができます(わずかなパフォーマンスの低下はありますが): http://www.mattinsler.com/post/ 26396305882/announcing-longjohn-long-stack-traces forノードjs

9
Tim Boudreau

Error.captureStackTrace(targetObject [、constructorOpt]) を試してください。

const myObj = {};
function c() {
  // pass
}

function b() {
    Error.captureStackTrace(myObj)
    c()
} 

function a() {
    b()
}

a()

console.log(myObj.stack)

関数abはエラースタックにキャプチャされ、myObjに格納されます。

3
Zheeeng

Nodejsに完全なスタックトレースを表示することは不可能ですが、「部分的な」スタックトレースを表示するだけで、コード内のどこから来たのか、例外が発生したところからはわかりません。それが、このYouTubeビデオでRyan Dahlが説明していることです。正確であるため、 http://youtu.be/jo_B4LTHi3I 56分30分。お役に立てれば

3
ElHacker

エラーのスタックトレースのみを記録したい(エラーメッセージは記録したくない)場合は、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
GrayedFox

@ isaacs 答えは正しいですが、もっと正しい答えがあります。この答えは、ノードjsのConsoleクラスの元のソースコード( のソースコード )にヒントを得たものです。

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

  Error.captureStackTrace(err, getStack);

  return err.stack;
}
1

私のように誰かがまだこれを探している場合、「スタックトレース」と呼ばれる使用可能なモジュールがあります。本当に人気があります。 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();
1
Laszlo

コールスタックを追跡するための強力なモジュールである node-stack-trace モジュールを使用できます。

0
Nitin9791