Czy ktoś wie, jak wydrukować ślad stosu w Node.js?
Czy ktoś wie, jak wydrukować ślad stosu w Node.js?
Odpowiedzi:
Każdy Error
obiekt ma stack
element, który przechwytuje punkt, w którym został skonstruowany.
var stack = new Error().stack
console.log( stack )
lub prościej:
console.trace("Here I am!")
'util'
.
new Error().stack
, co działa w przypadkach, gdy nie chcesz angażować konsoli.
trace
jest to, że pokazuje również bieżącą linię / kontekst, a która stack
nie. Informacja znajduje się w obiekcie błędu, jeśli myślę, że chcesz ręcznie utworzyć tę linię.
Teraz na konsoli jest dedykowana funkcja :
console.trace()
console.trace()
.
--stack_trace_limit=200
Jak już odpowiedziano, możesz po prostu użyć polecenia trace :
console.trace("I am here");
Jednakże, jeśli przyszedł na to pytanie szukasz informacji na temat logowania ślad stosu wyjątku , można po prostu zalogować obiekt wyjątku.
try {
// if something unexpected
throw new Error("Something unexpected has occurred.");
} catch (e) {
console.error(e);
}
Będzie rejestrować:
Błąd: Wystąpiło coś nieoczekiwanego.
at main (c: \ Users \ Me \ Documents \ MyApp \ app.js: 9: 15)
w Object. (c: \ Users \ Me \ Documents \ MyApp \ app.js: 17: 1)
w Module._compile (module.js: 460: 26)
w Object.Module._extensions..js (module.js: 478: 10 )
w Module.load (module.js: 355: 32)
w Function.Module._load (module.js: 310: 12)
w Function.Module.runMain (module.js: 501: 10)
przy uruchomieniu (node.js : 129: 16)
w node.js: 814: 3
Jeśli wersja Node.js jest mniejsza niż 6.0.0 , rejestrowanie obiektu wyjątku nie będzie wystarczające. W takim przypadku zostanie wydrukowane tylko:
[Błąd: Wystąpiło coś nieoczekiwanego.]
W przypadku wersji węzła <6 użyj console.error(e.stack)
zamiast, console.error(e)
aby wydrukować komunikat o błędzie plus pełny stos, podobnie jak obecna wersja węzła.
Uwaga: jeśli wyjątek jest tworzony jako ciąg znaków throw "myException"
, nie jest możliwe odzyskanie śladu stosu, a wyniki rejestrowania e.stack
są niezdefiniowane .
Aby być bezpiecznym, możesz użyć
console.error(e.stack || e);
i będzie działać dla starych i nowych wersji Node.js.
console.error(e)
wydrukuje wszystkiego w e
obiekcie, w tym e.stack
?
Aby wydrukować stos śledzenia Error
w konsoli w bardziej czytelny sposób:
console.log(ex, ex.stack.split("\n"));
Przykładowy wynik:
[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)' ]
Dzięki łatwo dostępnemu modułowi Węzła można uzyskać ślady stosu o pełnej długości z Węzła (aczkolwiek z niewielką utratą wydajności): http://www.mattinsler.com/post/26396305882/announcing-longjohn-long-stack -traces-for-node-js
Spróbuj Error.captureStackTrace (targetObject [, constructorOpt]) .
const myObj = {};
function c() {
// pass
}
function b() {
Error.captureStackTrace(myObj)
c()
}
function a() {
b()
}
a()
console.log(myObj.stack)
Funkcja a
i b
są przechwytywane w stos błędów i przechowywane w myObj
.
stack
własności, trzeba zadzwonić, jeśli ten węzeł> = 6: Error.captureStackTrace(error)
.
Error.captureStackTrace
pojawiła się w śladzie stosu, możesz ją pominąć, przekazując ją jako constructorOpt
argument.
Z tego co wiem, drukowanie pełnego śladu stosu w nodejs nie jest możliwe, możesz po prostu wydrukować „częściowy” ślad stosu, którego nie widzisz w kodzie, tylko gdzie występuje wyjątek. Tak wyjaśnia Ryan Dahl w tym filmie na youtube. http://youtu.be/jo_B4LTHi3I o min. 56:30 za precyzję. Mam nadzieję że to pomoże
Odpowiedź @isaacs jest poprawna, ale jeśli potrzebujesz bardziej szczegółowego lub czystszego stosu błędów , możesz użyć tej funkcji:
function getCleanerStack() {
var err = new Error();
Error.captureStackTrace(err, getStack);
return err.stack;
}
Ta funkcja jest zainspirowana bezpośrednio z console.trace
funkcji w NodeJS .
Kod źródłowy: najnowsza wersja lub stara wersja .
err.stack
jest bardziej poprawna odpowiedź.
Jeśli chcesz rejestrować tylko ślad stosu błędu (a nie komunikat o błędzie), Węzeł 6 i wyżej automatycznie dołącza nazwę błędu i komunikat do śladu stosu, co jest nieco denerwujące, jeśli chcesz wykonać niestandardową obsługę błędów:
console.log(error.stack.replace(error.message, ''))
To obejście spowoduje rejestrowanie tylko nazwy błędu i śledzenia stosu (dzięki czemu można na przykład sformatować komunikat o błędzie i wyświetlić go tak, jak chcesz w innym miejscu kodu).
Powyższy przykład wypisuje tylko nazwę błędu, po której następuje ślad stosu, na przykład:
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)
Zamiast:
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)
W przypadku, gdy ktoś nadal tego szuka, tak jak ja, istnieje moduł, którego możemy użyć o nazwie „stack-trace”. To jest bardzo popularne. Link NPM
Następnie przejdź przez ślad.
var stackTrace = require('stack-trace');
.
.
.
var trace = stackTrace.get();
trace.map(function (item){
console.log(new Date().toUTCString() + ' : ' + item.toString() );
});
Lub po prostu wydrukuj ślad:
var stackTrace = require('stack-trace');
.
.
.
var trace = stackTrace.get();
trace.toString();
możesz użyć modułu śledzenia stosu węzłów, który jest modułem o pełnej mocy do śledzenia stosów wywołań.
sys.puts(new Error().stack)
(po dodaniu modułu systemowego)