Setiap sistem pembalakan yang mantap terdiri daripada tiga komponen utama: Pengumpul, Storan dan Visualizer. Modul pengelogan Node.js yang popular seperti Winston dan Pino berfungsi sebagai pengumpul log semata-mata. Errsole, bagaimanapun, menawarkan penyelesaian pengelogan lengkap yang merangkumi:
Storan Log: Simpan log dalam fail atau pangkalan data aplikasi anda.
Papan Pemuka Terbina dalam: Lihat, tapis dan cari log menggunakan papan pemuka terbina dalam.
Makluman: Terima pemberitahuan masa nyata untuk ralat kritikal.
Untuk menggunakan Errsole, anda perlu memasang modul Errsole bersama modul storan berdasarkan pangkalan data pilihan anda. Berikut ialah langkah pemasangan untuk pilihan storan yang berbeza:
npm install errsole errsole-sqlite
npm install errsole errsole-mongodb
npm install errsole errsole-mysql
npm install errsole errsole-postgres
Dalam projek Node.js kehidupan sebenar, anda akan mempunyai berbilang fail. Untuk menggunakan Errsole Logger dalam setiap fail projek anda, buat fail logger.js dan mulakan Errsole di dalamnya:
const errsole = require('errsole'); const ErrsoleSQLite = require('errsole-sqlite'); errsole.initialize({ storage: new ErrsoleSQLite('/tmp/logs.sqlite') }); module.exports = errsole;
Kini, anda boleh mengimport fail logger.js dalam setiap fail dalam projek anda dan menggunakannya untuk log:
const logger = require('./logger'); // Example usage logger.info('This is an informational message.'); logger.error('This is an error message.');
Fungsi Errsole Logger mengambil hujah yang sama seperti console.log. Anda boleh menyediakan satu atau lebih rentetan, objek atau pembolehubah yang dipisahkan dengan koma. Selain itu, anda boleh melampirkan metadata pada mesej log anda menggunakan fungsi meta. Metadata ini boleh berupa sebarang maklumat kontekstual, seperti permintaan HTTP atau hasil pertanyaan pangkalan data.
logger.meta({ reqBody: req.body, queryResults: results }).error(err); logger.meta({ email: req.body.email }).log('User logged in');
Errsole Logger menyediakan fungsi untuk lima peringkat log: makluman, ralat, amaran, maklumat dan nyahpepijat.
log / maklumat: Gunakan untuk log mesej atau maklumat.
logger.log('Logging a message'); logger.log('Multiple', 'arguments', 'are supported'); logger.log('Logging with a variable:', var1); logger.log(new Error('An error occurred')); logger.log('Logging with an error object:', errorObject);
makluman: Log mesej dan menghantar pemberitahuan kepada saluran yang dikonfigurasikan, seperti E-mel atau Slack.
logger.alert('Alert! Something critical happened');
ralat: Direka khusus untuk mengelog ralat.
logger.error(new Error('An error occurred'));
amaran: Log mesej amaran.
logger.warn('This is a warning message');
nyahpepijat: Log maklumat nyahpepijat, biasanya digunakan untuk menyelesaikan masalah semasa pembangunan.
logger.debug('Debugging information');
Setiap kali aplikasi Node.js anda ranap, Errsole menghantar pemberitahuan masa nyata kepada pasukan pembangunan anda. Pemberitahuan ini termasuk mesej ralat, nama apl, nama persekitaran dan nama pelayan.
Untuk menambah ralat kritikal pada senarai pemberitahuan ini, gunakan logger.alert dalam kod anda. Walau bagaimanapun, elakkan menggunakannya secara berlebihan untuk mengelakkan membanjiri pembangun anda dengan pemberitahuan. Gunakannya untuk ralat kritikal seperti kegagalan pembayaran atau kegagalan pertanyaan pangkalan data. Letakkan objek ralat dalam fungsi amaran dan tambah semua maklumat kontekstual dalam fungsi meta. Ini membolehkan pembangun menyahpepijat ralat kritikal dengan mudah.
logger.meta({ reqBody: req.body, queryResults: results }).alert(err);
Menggabungkan penyelesaian pengelogan lengkap ke dalam aplikasi Node.js anda memastikan pengurusan log yang mantap dan penyahpepijatan yang cekap. Errsole menyediakan storan log, papan pemuka terbina dalam dan pemberitahuan masa nyata, menjadikannya alat pengelogan yang lengkap.
Untuk bermula dengan Errsole, lawati https://github.com/errsole/errsole.js.
Atas ialah kandungan terperinci Mencipta Logger Tersuai untuk Aplikasi Node.js menggunakan Errsole. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!