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.
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.
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.
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.
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.
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
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!