如何在Node.js中打印堆栈跟踪?

2020/09/24 22:21 · javascript ·  · 0评论

有人知道如何在Node.js中打印堆栈跟踪吗?

任何Error对象都具有stack捕获其构造点成员。

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

或更简单地说:

console.trace("Here I am!")

现在控制台上有一个专用功能

console.trace()

正如已经回答的那样,您可以简单地使用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


    )


    位于Object.Module._extensions..js(module.js:478:10
的Module._compile(module.js:460:26)


    在

    启动时(node.js


    )


    在Function.Module.runMain(module.js:501:10)

Function.Module._load(module.js:310:12 在Module.load(module.js:355:32):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。

Error以更易读的方式在控制台中打印stacktrace

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)' ]

使用现成的Node模块,可以从Node获得全长堆栈跟踪(尽管会降低性能):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)

函数ab被捕获在错误堆栈中并存储在中myObj

@isaacs答案是正确的,但是如果您需要更具体或更清晰的错误堆栈,则可以使用以下功能:

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

   return err.stack;
}

此功能直接来自NodeJS中console.trace功能

源代码:最新版本旧版本

对于我所知不可能在nodejs中打印完整的堆栈跟踪信息,您只能打印“部分”堆栈跟踪信息,看不到代码中的来源以及异常发生的位置。这就是Ryan Dahl在此youtube视频中解释的内容。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)

如果有人仍然像我一样寻找这个,那么我们可以使用一个称为“ stack-trace”的模块。真的很受欢迎。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模块,它是功能强大的模块,可以跟踪调用堆栈。

本文地址:http://javascript.askforanswer.com/ruhezainode-jszhongdayinduizhangenzong.html
文章标签: ,   ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!