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


回答:


615

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

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

またはもっと簡単に:

console.trace("Here I am!")

1
またはsys.puts(new Error().stack)(システムモジュールを追加した後)
sirhc

5
現在のところ、sysは廃止されています。に置き換えられ'util'ます。
Pindatjuh

12
+1も表示しnew Error().stackます。これは、コンソールを使用したくない場合に機能します。
Eugene Beresovsky

1
の利点の1つtraceは、現在の行/コンテキストも表示するが、表示stackしないことです。その行を手動で作成したい場合、情報はエラーオブジェクトにあります。
studgeek 2012

130
console.log(err.stack)とconsole.trace()は同じ結果を与えません。err.stackはerrオブジェクト自体のスタックトレースを提供するのに対し(constraint.trace()は、console.trace()が呼び出された時点でコールスタックを出力します。したがって、コードのより深い層によってスローされているエラーをキャッチした場合、console.trace()はスタックトレースにそのより深い層のコードを含まないでしょう。ただし、console.log(err.stack)には、Errorオブジェクトをスローする限り、より深い層が含まれます。
d512 2013

200

これで、コンソール専用の関数があります:

console.trace()

11
に関する上記のコメントに注意してくださいconsole.trace()
Qix-モニカは2014

5
デフォルトでは、これが唯一例えば、あなたがこれを高めるために、コマンドライン引数を使用することができ、10個のフレームが表示されます--stack_trace_limit=200
マイケル・

ログファイルに出力したい場合は?
はい。

それはpromiseとasync / awaitでは機能しないようですが、そうですか?
bluenote10

97

すでに回答したように、単に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)
    at Object.Module._extensions..js(module.js:478:10 )
    Module.load(module.js:355:32)
    at Function.Module._load(module.js:310:12)
    at Function.Module.runMain(module.js:501:10)
    at startup(node.js :129:16)
    node.js:814:3で


Node.jsのバージョンが6.0.0未満の場合、Exceptionオブジェクトをログに記録するだけでは不十分です。この場合、印刷されるのは次のものだけです。

[エラー:予期しないことが発生しました。]

ノードのバージョンが6未満の場合、のconsole.error(e.stack)代わりにconsole.error(e)を使用して、現在のノードのバージョンのように、エラーメッセージと完全なスタックを出力します。


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

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

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

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


オブジェクトを含むすべてconsole.error(e)印刷しませんか?ee.stack
drmrbrewer 2017年

1
@drmrbrewer、これを指摘してくれてありがとう。Nodeバージョン4.xと7.xの間で動作が変更されたようです(おそらくV8の変更)。回答を更新しました。
Zanon

1
@drmrbrewerは、この動作がバージョン6.0.0で変更されたことを確認しました
Zanon

2
申し訳ありませんが、重要なものを発見しました。関連する投稿に対する私のコメントをご覧ください:stackoverflow.com/questions/42528677/…。実際にエラーをログに記録すると、エラーの内容全体が実際に表示されるようですが、それを(文字列のように)他のテキストと連結しようとすると、短いメッセージ部分のみが使用されます。その実現により、すべてのことがはるかに理にかなっています。
drmrbrewer 2017年

1
あなたは私の日を保存します)
アレックス

39

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

すぐに利用できるノードモジュールを使用すると、ノードからフルレングスのスタックトレースを取得することができます(パフォーマンスが若干低下します):http : //www.mattinsler.com/post/26396305882/announcing-longjohn-long-stack -traces-for-node-js


4
リンク切れですが、ここでアーカイブされたコピーを閲覧したり、ライブラリをチェックアウトしたりできます
2018年

5

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ます。


2
エラーにstackプロパティを持たせたい場合、Node> = 6:の場合にこれを呼び出す必要がありますError.captureStackTrace(error)
cjbarth 2018

呼び出したフレームがError.captureStackTraceスタックトレースに表示されないようにする場合は、constructorOptarg として渡すことで省略できます。
ウラウリ

3

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


2
真実ですが、@ Timboudreauの回答のモジュールはそれを「修正」します
Bogdan D

3

@isaacsの答えは正しいですが、より具体的またはより明確なエラースタックが必要な場合は、次の関数を使用できます。

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

   return err.stack;
}

この関数はNodeJSconsole.trace関数から直接発想を得ています。

ソースコード:最近のバージョンまたは古いバージョン


1
これは機能せず、現在の行のスタックのみを表示します(このエラーが発生した行ではありません)。err.stackより正解です。
Ian Zhong

2

エラーのスタックトレースのみを記録し、エラーメッセージはログに記録しない場合、ノード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

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

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.