Node.jsでスタックトレースを印刷する方法を知っている人はいますか?
Node.jsでスタックトレースを印刷する方法を知っている人はいますか?
回答:
どのError
オブジェクトにも、stack
そのオブジェクトが構築されたポイントをトラップするメンバーがあります。
var stack = new Error().stack
console.log( stack )
またはもっと簡単に:
console.trace("Here I am!")
'util'
ます。
new Error().stack
ます。これは、コンソールを使用したくない場合に機能します。
trace
は、現在の行/コンテキストも表示するが、表示stack
しないことです。その行を手動で作成したい場合、情報はエラーオブジェクトにあります。
console.trace()
。
--stack_trace_limit=200
すでに回答したように、単に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)
印刷しませんか?e
e.stack
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)' ]
すぐに利用できるノードモジュールを使用すると、ノードからフルレングスのスタックトレースを取得することができます(パフォーマンスが若干低下します):http : //www.mattinsler.com/post/26396305882/announcing-longjohn-long-stack -traces-for-node-js
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
ます。
stack
プロパティを持たせたい場合、Node> = 6:の場合にこれを呼び出す必要がありますError.captureStackTrace(error)
。
Error.captureStackTrace
スタックトレースに表示されないようにする場合は、constructorOpt
arg として渡すことで省略できます。
nodejsで完全なスタックトレースを印刷することは不可能であることがわかっているため、「部分的な」スタックトレースを印刷するだけで、コードのどこから来たのか、例外が発生した場所を確認できません。それが、このyoutubeビデオでRyan Dahlが説明していることです。http://youtu.be/jo_B4LTHi3I 正確さ分間56:30時。お役に立てれば
エラーのスタックトレースのみを記録し、エラーメッセージはログに記録しない場合、ノード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)
私のように誰かがまだこれを探している場合、「スタックトレース」と呼ばれる使用可能なモジュールがあります。とても人気があります。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();
コールスタックを追跡するためのパワーフルモジュールであるnode-stack-traceモジュールを使用できます。
sys.puts(new Error().stack)
(システムモジュールを追加した後)