Konsep Utama
NODE_ENV=development
Melaksanakan pembalakan strategik menggunakan --inspect
atau modul pihak ketiga seperti Winston untuk menangkap log terperinci, konteks khusus untuk analisis menyeluruh. util.debuglog
--inspect
Debugging adalah proses mengenal pasti dan menyelesaikan kecacatan perisian. Semasa menetapkan pepijat sering mudah, mencari punca akar boleh memakan masa. Node.js menawarkan alat yang berkuasa untuk menyelaraskan proses ini.
Debugging terminology
Term | Explanation |
---|---|
Breakpoint | A point in the code where the debugger pauses execution, allowing inspection of the program's state. |
Debugger | A tool providing debugging functionalities, such as stepping through code line by line and inspecting variables. |
Feature (not bug) | A common developer phrase used to jokingly dismiss a reported bug. |
Frequency | How often a bug occurs under specific conditions. |
"It doesn't work" | A vague and unhelpful bug report. |
Log Point | An instruction to the debugger to display a variable's value at a specific point during execution. |
Logging | Outputting runtime information to the console or a file. |
Logic Error | The program runs without crashing, but produces incorrect results. |
Priority | The ranking of a bug's importance in the list of planned updates. |
Race Condition | A hard-to-trace bug caused by the unpredictable sequence or timing of events. |
Refactoring | Rewriting code to improve readability and maintainability. |
Regression | The re-emergence of a previously fixed bug, often due to subsequent code changes. |
Related Bug | A bug similar to or connected to another bug. |
Reproduce | The steps needed to trigger the error. |
RTFM Error | User error disguised as a bug report (Read The Flipping Manual). |
Step Into | In a debugger, execute a function call line by line. |
Step Out | In a debugger, complete the current function's execution and return to the calling code. |
Step Over | In a debugger, execute a command without stepping into any functions it calls. |
Severity | The impact of a bug on the system (e.g., data loss is more severe than a minor UI issue). |
Stack Trace | A historical list of all functions called before an error occurred. |
Syntax Error | Errors caused by typos or incorrect code structure (e.g., console.lug() ). |
User Error | An error caused by user actions, but may still require a fix depending on the user's role. |
Watch | A variable monitored during debugger execution. |
Watchpoint | Similar to a breakpoint, but the program pauses only when a specific variable reaches a particular value. |
Mencegah Bugs
Langkah -langkah proaktif dapat mengurangkan kejadian bug.
Gunakan editor kod yang mantap
Editor kod yang baik menawarkan ciri-ciri seperti penomboran talian, penyempurnaan automatik, penonjolan sintaks, pemadanan kurungan, pemformatan, dan banyak lagi, meningkatkan kualiti kod dan mengurangkan kesilapan. Pilihan popular termasuk kod vs, atom, dan kurungan.
menggunakan kod linter
Linters mengenal pasti isu -isu kod yang berpotensi (kesilapan sintaks, masalah lekukan, pembolehubah yang tidak diisytiharkan) sebelum ujian. Eslint, JSLint, dan JSHint adalah pilihan popular untuk JavaScript dan Node.js. Mereka boleh dijalankan dari baris perintah (eslint myfile.js
Sistem kawalan sumber (mis., Git) Perubahan kod trek, menjadikannya lebih mudah untuk mengenal pasti kapan dan di mana pepijat diperkenalkan. Repositori dalam talian seperti GitHub dan Bitbucket menyediakan alat dan penyimpanan yang mudah.
Melaksanakan sistem penjejakan isu
Sistem penjejakan isu membantu menguruskan laporan pepijat, mengesan pendua, langkah pembiakan dokumen, menetapkan keutamaan, dan memantau kemajuan. Banyak repositori dalam talian termasuk pengesanan isu asas, tetapi penyelesaian yang berdedikasi lebih baik untuk projek yang lebih besar.
Mengadopsi Pembangunan yang Diteruskan Ujian (TDD)
TDD melibatkan ujian menulis
sebelumkod, memastikan fungsi dan menangkap isu -isu awal.
Ambil rehatmelangkah jauh dari debug untuk seketika sering dapat membawa kepada pandangan dan penyelesaian segar.
node.js debugging: pembolehubah persekitaran
Pemboleh ubah persekitaran mengawal tetapan aplikasi Node.js.
biasanya ditetapkan kepada semasa debugging. Pembolehubah boleh ditetapkan pada linux/macOS (NODE_ENV
), Windows CMD (development
). Mereka juga boleh disimpan dalam fail NODE_ENV=development
dan dimuat menggunakan modul set NODE_ENV=development
. $env:NODE_ENV="development"
.env
dotenv
debug node.js: Pilihan baris arahan
Pilihan baris perintah mengubah suai tingkah laku runtime Node.js. output jejak tumpukan untuk amaran (termasuk pengurangan). Pilihan lain termasuk
,, dan --trace-warnings
. --enable-source-maps
--throw-deprecation
--inspect
debugging konsol
console.log()
adalah alat debugging asas tetapi penting. Walau bagaimanapun, terokai kaedah console
yang lain: .dir()
, .table()
, .error()
, .count()
, .group()
, .time()
, .trace()
, dan .clear()
. ES6 Destructuring memudahkan objek kompleks pembalakan.
node.js util.debuglog
Secara syarat menulis mesej kepada stderr, hanya diaktifkan apabila pembolehubah persekitaran util.debuglog
ditetapkan dengan sewajarnya. Ini membolehkan untuk meninggalkan pernyataan debug dalam kod tanpa menggagalkan konsol semasa operasi biasa. NODE_DEBUG
Debugging dengan modul log
Modul Pembalakan Pihak Ketiga (Kabin, Loglevel, Morgan, Pino, Signale, dll.) Menawarkan ciri-ciri canggih seperti tahap pembalakan, kawalan keliangan, output fail, dan banyak lagi.node.js v8 Inspektor
Inspektor V8 adalah alat debugging yang kuat. Mulakan aplikasi dengan
. Perintah termasuk (meneruskan), node inspect ./index.js
(perintah seterusnya), cont
(langkah ke), next
(langkah keluar), step
, out
, pause
, dan watch
. setBreakpoint()
.exit
Gunakan
untuk memulakan pemeriksa, mendengar port 9229. Tetapkan titik putus, tonton pembolehubah, dan periksa timbunan panggilan. Untuk penyahpepijatan jauh, gunakan. node --inspect ./index.js
chrome://inspect
node --inspect=0.0.0.0:9229 ./index.js
node.js debugging dengan vs code
vs kod menyediakan debugging node.js bersepadu. Tetapkan titik putus dengan mengklik dalam longkang, atau gunakan titik putus bersyarat dan titik log. Untuk debugging jauh atau konfigurasi lanjutan, gunakan fail .
launch.json
), NDB, IBM Report-Toolkit, dan perkhidmatan komersial seperti Logrocket dan Sentry.io.
Kesimpulan node-debug
tetap berguna, memanfaatkan pilihan yang lebih maju untuk debugging yang cekap.
Soalan Lazim (Soalan Lazim) console.log()
node inspect your-script.js
atau node inspect-brk your-script.js
. inspect
dan inspect-brk
? inspect
dilampirkan selepas permulaan; inspect-brk
pecah pada mulanya. debugger;
, perintah debugger, atau klik dalam longkang editor (dalam ides). console.log()
? Maklumat output ke konsol untuk pemeriksaan. async/await
dan tetapkan titik putus dalam fungsi async. --inspect
debugging jauh? clinic.js
Tentukan pilihan tuan rumah dan pelabuhan apabila memulakan debugger dan bersambung dari persekitaran tempatan anda. Atas ialah kandungan terperinci Cara Debug A Node.js Aplikasi: Petua, Trik dan Alat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!