


Bagaimana untuk mendayakan penyahpepijatan nodejs? Bagaimana untuk menyahpepijat program nodejs?
Bagaimana untuk nyahpepijat program nodejs? Artikel berikut akan memperkenalkan anda kepada kaedah penyahpepijatan nodejs saya harap ia akan membantu anda!
Bagi pembangun, dalam proses membangunkan aplikasi, mereka selalunya perlu menggunakan fungsi penyahpepijatan bahasa pengaturcaraan untuk memudahkan pembangunan dan menyelesaikan pepijat. Secara umumnya, kita perlu menggunakan fungsi penyahpepijatan IDE yang berkuasa untuk menyelesaikan kerja ini. nodejs tidak terkecuali.
Hari ini kami akan memperkenalkan secara terperinci cara menyahpepijat program nod.
Dayakan penyahpepijatan nodej
Adakah anda masih ingat program koa yang kita bincangkan sebelum ini? Artikel ini akan mengambil program pelayan koa mudah sebagai contoh untuk memulakan penyahpepijatan nodej.
Mari kita lihat aplikasi perkhidmatan koa mudah.js dahulu:
const Koa = require('koa'); const app = module.exports = new Koa(); app.use(async function(ctx) { ctx.body = 'Hello World'; }); if (!module.parent) app.listen(3000);
Atur cara di atas membuka port 3000 dan mewujudkan perkhidmatan http. Setiap kali permintaan dibuat, hello World akan dikembalikan, yang sangat mudah.
Untuk menjalankan program di atas, kita perlu melaksanakan nod app.js. Ini akan melaksanakan app.js tetapi tidak akan mendayakan penyahpepijatan.
Bagaimana untuk nyahpepijat?
Kami perlu menambah parameter --inspect:
node --inspect app.js
Kod di atas akan membolehkan fungsi penyahpepijatan nodejs.
Mari kita lihat output:
Debugger listening on ws://127.0.0.1:9229/88c23ae3-9081-41cd-98b0-d0f7ebceab5a For help, see: https://nodejs.org/en/docs/inspector
Hasilnya memberitahu kita dua perkara yang pertama ialah port yang didengari oleh penyahpepijat. Secara lalai, port 9229 127.0.0.1 akan dibuka. Dan memberikan UUID unik untuk pembezaan.
Perkara kedua ialah memberitahu kami bahawa penyahpepijat yang digunakan oleh nodejs ialah Inspektor.
Inspektor telah diperkenalkan selepas nodejs 8. Jika sebelum nodejs 7, maka penyahpepijat lama digunakan.
Keselamatan penyahpepijatan
Jika penyahpepijat disambungkan ke persekitaran berjalan nodejs, jika terdapat penyerang berniat jahat, penyerang berniat jahat boleh menjalankan kod arbitrari dalam persekitaran nodejs . Ini akan membawa risiko keselamatan yang besar kepada program kami.
Jadi kita mesti memberi perhatian kepada keselamatan penyahpepijatan. Secara umumnya, kami tidak mengesyorkan penyahpepijatan jauh.
Secara lalai, --inspect terikat kepada 127.0.0.1, yang hanya membenarkan program tempatan mengakses. Dan mana-mana program yang dijalankan secara tempatan mempunyai kebenaran untuk menyahpepijat program.
Jika kami benar-benar ingin mendedahkan program nyahpepijat kepada program luaran, kami boleh menentukan alamat IP luaran mesin atau 0.0.0.0 (menunjukkan sebarang alamat, tiada sekatan), supaya mesin jauh boleh melakukan alat kawalan jauh Dinyahpepijat.
Apakah yang perlu kita lakukan jika kita ingin melakukan penyahpepijatan jauh yang selamat?
Pertama, kita perlu mendayakan penyahpepijatan setempat:
node --inspect app.js
Kemudian kita boleh membina terowong ssh untuk memetakan port 9221 tempatan ke port 9229 pelayan jauh:
ssh -L 9221:localhost:9229 user@remote.example.com
Dengan cara ini, kami boleh melakukan penyahpepijatan jauh dengan menyambung ke port 9221 tempatan.
Gunakan WebStorm untuk penyahpepijatan nodej
WebStorm yang dihasilkan oleh JetBrains boleh dikatakan sebagai alat yang berkuasa untuk membangunkan nodejs mempunyai pilihan nyahpepijatnya sendiri dihidupkan, ia akan dinyahpepijat di latar belakang Hidupkan --inspect:
Menggunakan WebStorm untuk penyahpepijatan adalah serupa dengan menggunakan IDEA untuk penyahpepijatan program java, jadi saya akan' t pergi ke butiran di sini.
Gunakan Chrome devTools untuk penyahpepijatan
Prasyarat untuk menggunakan Chrome devTools untuk penyahpepijatan ialah kami telah menghidupkan mod --inspect.
Masukkan chrome://inspect dalam chrome:
Kita boleh melihat antara muka pemeriksaan chrome, jika anda sudah mempunyai program nodejs yang telah memeriksa didayakan secara setempat Jika ya, anda boleh melihatnya terus dalam Sasaran Jauh.
Pilih sasaran yang anda mahu nyahpepijat dan klik periksa untuk membuka alat penyahpepijat Chrome devTools:
Anda boleh memprofilkan atur cara dan nyahpepijatnya.
Di sini kami memfokuskan pada penyahpepijatan, jadi pergi ke lajur sumber dan tambahkan kod sumber program yang ingin anda nyahpepijat:
Hanya tambahkan Penyahpepijatan titik putus bermula. Ia adalah sama seperti penyahpepijatan js di bahagian web dalam chrome.
Gunakan nod-inspect untuk penyahpepijatan
Malah, nodejs mempunyai alat penyahpepijatan terbina dalam dipanggil node-inspect, iaitu alat penyahpepijatan cli. Mari lihat cara menggunakannya.
Kami secara langsung menggunakan:
node inspect app.js < Debugger listening on ws://127.0.0.1:9229/f1c64736-47a1-42c9-9e9e-f2665073d3eb < For help, see: https://nodejs.org/en/docs/inspector < Debugger attached. Break on start in app.js:1 > 1 const Koa = require('koa'); 2 const app = module.exports = new Koa(); 3 debug>
pemeriksaan nod melakukan dua perkara Perkara pertama ialah menjana subrutin untuk menjalankan nod --inspect app.js, dan perkara kedua ialah Jalankan. Tetingkap nyahpepijat CLI dalam program utama.
Penyahpepijat CLI ini memberikan kita beberapa arahan yang sangat berguna:
1. Melangkah
- samb, c : Teruskan ke. laksanakan
- seterusnya, n: Langkah ke langkah seterusnya
- langkah, s: Langkah masuk
- keluar, o: Langkah keluar
- jeda: Jeda Berlari kod
2 Maklumat Melalui arahan di atas, kita boleh melakukan aktiviti penyahpepijatan yang lebih kompleks dalam CLI. Selain yang kami nyatakan di atas, kami juga boleh menggunakan vscode, Visual Studio, Eclipse IDE, dsb. untuk melaksanakan Penyahpepijatan nodej tidak akan diperkenalkan secara terperinci di sini. Rakan yang berminat boleh meneroka sendiri. Untuk lebih banyak pengetahuan berkaitan nod, sila lawati: tutorial nodejs! !
Klien nyahpepijat lain
Atas ialah kandungan terperinci Bagaimana untuk mendayakan penyahpepijatan nodejs? Bagaimana untuk menyahpepijat program nodejs?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Penyahpepijatan berbilang benang boleh menggunakan GDB: 1. Dayakan penyusunan maklumat penyahpepijatan; 2. Tetapkan titik putus; Kebuntuan penyahpepijatan kes sebenar: 1. Gunakan threadapplyalbt untuk mencetak tindanan;

Bagaimana cara menggunakan LeakSanitizer untuk menyahpepijat kebocoran memori C++? Pasang LeakSanitizer. Dayakan LeakSanitizer melalui bendera kompilasi. Jalankan aplikasi dan analisis laporan LeakSanitizer. Kenal pasti jenis peruntukan memori dan lokasi peruntukan. Betulkan kebocoran memori dan pastikan semua memori yang diperuntukkan secara dinamik dikeluarkan.

Artikel ini memperkenalkan pintasan untuk penyahpepijatan dan analisis fungsi Go, termasuk: dlv penyahpepijat terbina dalam, yang digunakan untuk menjeda pelaksanaan, menyemak pembolehubah dan menetapkan titik putus. Log, gunakan pakej log untuk merakam mesej dan melihatnya semasa penyahpepijatan. Alat analisis prestasi pprof menjana graf panggilan dan menganalisis prestasi, serta menggunakan gotoolpprof untuk menganalisis data. Kes praktikal: Analisis kebocoran memori melalui pprof dan hasilkan graf panggilan untuk memaparkan fungsi yang menyebabkan kebocoran.

Nyahpepijat ungkapan Lambda dengan cekap: IntelliJ IDEA Debugger: Tetapkan titik putus pada pengisytiharan atau kaedah pembolehubah, periksa pembolehubah dan keadaan dalaman dan lihat kelas pelaksanaan sebenar. Java9+JVMTI: Sambung ke JVM masa jalan untuk mendapatkan pengecam, periksa bytecode, tetapkan titik putus dan pantau pembolehubah dan status semasa pelaksanaan.

Alat untuk menyahpepijat kod tak segerak PHP termasuk: Psalm: alat analisis statik yang menemui kemungkinan ralat. ParallelLint: Alat yang memeriksa kod tak segerak dan memberikan cadangan. Xdebug: Sambungan untuk menyahpepijat aplikasi PHP dengan mendayakan sesi dan melangkah melalui kod. Petua lain termasuk menggunakan pengelogan, penegasan, kod berjalan secara setempat dan menulis ujian unit.

Ujian dan penyahpepijatan serentak Ujian dan penyahpepijatan serentak dalam pengaturcaraan serentak Java adalah penting dan teknik berikut tersedia: Ujian serentak: Ujian unit: Asingkan dan uji satu tugas serentak. Ujian integrasi: menguji interaksi antara pelbagai tugas serentak. Ujian beban: Nilaikan prestasi dan kebolehskalaan aplikasi di bawah beban berat. Penyahpepijatan Konkurensi: Titik Putus: Jeda pelaksanaan utas dan periksa pembolehubah atau jalankan kod. Pengelogan: Rekod peristiwa dan status urutan. Jejak tindanan: Kenal pasti sumber pengecualian. Alat visualisasi: Pantau aktiviti benang dan penggunaan sumber.

Teknik berikut tersedia untuk menyahpepijat fungsi rekursif: Semak jejak tindananTetapkan titik nyahpepijatSemak jika kes asas dilaksanakan dengan betulKira bilangan panggilan rekursifVisualkan tindanan rekursif

Ralat penyahpepijatan PHP biasa termasuk: Ralat sintaks: Semak sintaks kod untuk memastikan tiada ralat. Pembolehubah tidak ditentukan: Sebelum menggunakan pembolehubah, pastikan ia dimulakan dan diberikan nilai. Koma bertitik tiada: Tambahkan koma bertitik pada semua blok kod. Fungsi tidak ditentukan: Semak sama ada nama fungsi dieja dengan betul dan pastikan fail atau sambungan PHP yang betul dimuatkan.
