ไม่มีใครรู้วิธีพิมพ์ stack trace ใน Node.js?
ไม่มีใครรู้วิธีพิมพ์ stack trace ใน 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()
console.trace()
เกี่ยวกับ
--stack_trace_limit=200
ตามคำตอบแล้วคุณสามารถใช้คำสั่งติดตาม :
console.trace("I am here");
อย่างไรก็ตามหากคุณมาที่คำถามนี้ค้นหาวิธีบันทึกการติดตามสแต็กของข้อยกเว้นคุณสามารถบันทึกวัตถุข้อยกเว้นได้
try {
// if something unexpected
throw new Error("Something unexpected has occurred.");
} catch (e) {
console.error(e);
}
มันจะเข้าสู่ระบบ:
ข้อผิดพลาด: มีบางสิ่งที่ไม่คาดคิดเกิดขึ้น
ที่ main (c: \ Users \ Me \ Documents \ MyApp \ app.js: 9: 15)
ที่ Object (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 (โมดูล.js: 501: 10)
เมื่อเริ่มต้น (node.js) : 129: 16)
ที่ node.js: 814: 3
หากเวอร์ชัน Node.js ของคุณคือ <มากกว่า 6.0.0การบันทึกวัตถุข้อยกเว้นจะไม่เพียงพอ ในกรณีนี้มันจะพิมพ์เท่านั้น:
[ข้อผิดพลาด: มีบางอย่างไม่คาดคิดเกิดขึ้น]
สำหรับโหนดเวอร์ชัน <6 ให้ใช้console.error(e.stack)
แทนconsole.error(e)
เพื่อพิมพ์ข้อความแสดงข้อผิดพลาดพร้อมกับสแต็กเต็มรูปแบบเช่นเดียวกับรุ่นโหนดปัจจุบัน
หมายเหตุ:ถ้ายกเว้นจะถูกสร้างขึ้นเป็นสตริงเหมือนthrow "myException"
มันเป็นไปไม่ได้ที่จะดึงกองติดตามและเข้าสู่ระบบe.stack
อัตราผลตอบแทนไม่ได้กำหนดไม่ได้กำหนด
เพื่อความปลอดภัยคุณสามารถใช้
console.error(e.stack || e);
และมันจะใช้ได้กับ Node.js ทั้งเก่าและใหม่
console.error(e)
พิมพ์ทุกอย่างในe
วัตถุe.stack
หรือไม่
หากต้องการพิมพ์ stacktrace Error
in ในคอนโซลในวิธีที่อ่านได้มากขึ้น:
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 สำหรับโหนด js
ลองError.captureStackTrace (Object เป้าหมาย [constructorOpt])
const myObj = {};
function c() {
// pass
}
function b() {
Error.captureStackTrace(myObj)
c()
}
function a() {
b()
}
a()
console.log(myObj.stack)
ฟังก์ชั่นa
และถูกจับในกองข้อผิดพลาดและเก็บไว้ในb
myObj
stack
คุณสมบัติที่คุณจะต้องเรียกสิ่งนี้ว่าถ้าโหน> = Error.captureStackTrace(error)
6:
Error.captureStackTrace
ให้แสดงในการติดตามสแต็กคุณสามารถข้ามมันได้โดยการผ่านมันเป็นconstructorOpt
arg
สำหรับสิ่งที่ฉันรู้ว่าการพิมพ์การติดตามสแต็กสมบูรณ์ใน nodejs เป็นไปไม่ได้คุณสามารถพิมพ์การติดตามสแต็ก "บางส่วน" คุณไม่สามารถดูได้ว่าคุณมาจากที่ใดในรหัสที่ซึ่งข้อยกเว้นเกิดขึ้น นั่นคือสิ่งที่ Ryan Dahl อธิบายในวิดีโอ youtube นี้ http://youtu.be/jo_B4LTHi3I เวลาขั้นต่ำ 56:30 เพื่อความแม่นยำ หวังว่านี่จะช่วยได้
@isaacsคำตอบถูกต้อง แต่ถ้าคุณต้องการสแต็คข้อผิดพลาดที่เฉพาะเจาะจงมากขึ้นหรือสะอาดกว่าคุณสามารถใช้ฟังก์ชั่นนี้:
function getCleanerStack() {
var err = new Error();
Error.captureStackTrace(err, getStack);
return err.stack;
}
ฟังก์ชั่นนี้เป็นแรงบันดาลใจโดยตรงจากconsole.trace
ฟังก์ชั่นในNodeJS NodeJS
รหัสที่มา: รุ่นล่าสุดหรือรุ่นเก่า
err.stack
เป็นคำตอบที่ถูกต้องมากขึ้น
หากคุณต้องการบันทึกการติดตามสแต็กของข้อผิดพลาดเท่านั้น (และไม่ใช่ข้อความแสดงข้อผิดพลาด) โหนด 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)
(หลังจากที่เพิ่มโมดูลระบบ)