cari
Rumahpembangunan bahagian belakangtutorial phpPembalakan dengan Monolog: Dari Devtools hingga Slack

Monolog: Perpustakaan Log PHP yang kuat yang membantu anda meningkatkan kecekapan pembangunan aplikasi dan penyelenggaraan

Rakaman log adalah bahagian yang sangat diperlukan dari kitaran pembangunan dan penyelenggaraan aplikasi, dan ia tidak hanya bergantung pada data yang direkodkan, tetapi juga dalam cara ia direkodkan. Artikel ini akan menyelam ke dalam pakej monolog untuk menunjukkan bagaimana ia dapat membantu anda memanfaatkan sepenuhnya log anda.

Logging with Monolog: From Devtools to Slack

Kelebihan teras:

  • Diintegrasikan secara meluas: Monolog adalah perpustakaan log popular yang mengintegrasikan dengan kebanyakan rangka kerja arus perdana untuk memudahkan pemaju untuk memanfaatkan keupayaan pembalakannya. Ia mengikuti standard PHP-FIG, menjadikannya mudah untuk beralih kepada pelaksanaan lain.
  • Pemprosesan fleksibel: Monolog menyokong pelbagai pemproses dan mekanisme menggelegak, yang membolehkan pemaju mencatatkan pelbagai jenis mesej ke output yang berbeza. Ia juga menyokong menghantar mesej log ke perkhidmatan luaran, seperti Slack, untuk memberitahu pasukan apabila berlaku ralat.
  • Kaya yang berfungsi:
  • Monolog menyediakan pelbagai preprocessors praktikal untuk mengandungi maklumat terperinci seperti puncak memori, ID pengguna, dan membolehkan format mesej log tersuai. Ini menjadikannya alat yang berkuasa untuk pembalakan dan debug semasa kitaran pembangunan/penyelenggaraan aplikasi.
  • Pemasangan:

Monolog boleh didapati di Packagist dan boleh dipasang melalui Komposer:

Jika anda menggunakan rangka kerja, monolog biasanya menyediakan penyelesaian integrasi. Contoh berikut tidak menggunakan integrasi rangka kerja dan menunjukkan cara mengkonfigurasi monolog dalam sebarang permohonan.

composer require 'monolog/monolog:1.13.*'

logger login:

Apabila membuat logger, anda harus menentukan nama saluran untuk membezakan pembalak yang berbeza. Contoh berikut mengikat logger ke bekas aplikasi:

Monolog mengikuti standard PSR-3, menjadikannya mudah untuk beralih kepada pelaksanaan lain. Anda boleh menggunakan kaedah berikut untuk pembalakan (log, debug, maklumat, amaran, kesilapan, kritikal, amaran, kecemasan):

// app/bootstrap/container.php

$logger = new \Monolog\Logger('general');
$app->container->logger = $logger;

pemproses:
$app->container->logger->info("一条INFO消息。");

Mesej log akan melalui senarai pemproses berdaftar. Pemproses perlu menentukan tahap log dan keadaan gelembung proses (sama ada mesej terus disebarkan). Secara lalai, Monolog menggunakan untuk log log ke output ralat standard. Pemproses yang ada disenaraikan dalam dokumentasi.

Contoh berikut menunjukkan cara menggunakan pelbagai pemproses dan mekanisme menggelegak: mesej maklumat log ke konsol penyemak imbas dan mesej ralat ke output terminal. MonologHandlerStreamHandler

// app/bootstrap/container.php

$logger = new \Monolog\Logger('general');

$browserHanlder = new \Monolog\Handler\BrowserConsoleHandler(\Monolog\Logger::INFO);
$streamHandler = new \Monolog\Handler\StreamHandler('php://stderr', \Monolog\Logger::ERROR);

$logger->pushHandler($browserHanlder);
$logger->pushHandler($streamHandler);

$app->container->logger = $logger;
// app/routes.php

$app->get('/admin/users', function () use ($app) {
    $app->container->logger->info("另一条INFO消息");
    $app->container->logger->error("另一条ERROR消息");
    // ...
});

Logging with Monolog: From Devtools to Slack Mesej ralat direkodkan ke terminal seperti yang diharapkan, tetapi mengapa mereka juga muncul dalam konsol penyemak imbas? Ini adalah mekanisme menggelegak monolog. Mesej ralat pertama kali dilog masuk ke terminal dan jika pilihan gelembung ditetapkan kepada benar, ia terus menyebarkan ke bahagian atas giliran pemproses. Tetapkan pilihan menggelegak Logging with Monolog: From Devtools to Slack kepada palsu:

composer require 'monolog/monolog:1.13.*'

Logging with Monolog: From Devtools to Slack Logging with Monolog: From Devtools to Slack

Log ralat kini tidak dipaparkan dalam konsol penyemak imbas, iaitu cara memisahkan tahap log.

pemproses slack:

Sebelum menggunakan pemproses Slack, anda perlu mendapatkan token untuk membenarkannya untuk menerbitkan ke saluran Slack.

// app/bootstrap/container.php

$logger = new \Monolog\Logger('general');
$app->container->logger = $logger;

Anda hanya perlu menentukan nama token dan saluran Slack, parameter pilihan ketiga adalah nama robot. Tahap log Slack adalah kritikal, tetapi anda boleh mengubahnya menggunakan kaedah setLevel.

$app->container->logger->info("一条INFO消息。");

Selepas menghantar mesej log, anda boleh mengakses saluran anda untuk melihat mesej ralat yang direkodkan.

// app/bootstrap/container.php

$logger = new \Monolog\Logger('general');

$browserHanlder = new \Monolog\Handler\BrowserConsoleHandler(\Monolog\Logger::INFO);
$streamHandler = new \Monolog\Handler\StreamHandler('php://stderr', \Monolog\Logger::ERROR);

$logger->pushHandler($browserHanlder);
$logger->pushHandler($streamHandler);

$app->container->logger = $logger;

Logging with Monolog: From Devtools to Slack

formatizer:

Setiap pemproses mempunyai formatter lalai, jika tidak ditentukan, gunakan

. Anda boleh beralih ke formatter lain seperti LineFormatter. HtmlFormatter

// app/routes.php

$app->get('/admin/users', function () use ($app) {
    $app->container->logger->info("另一条INFO消息");
    $app->container->logger->error("另一条ERROR消息");
    // ...
});
Mesej log kini akan dilog masuk ke konsol penyemak imbas dalam format HTML.

// app/bootstrap/container.php

// ...
$streamHandler = new \Monolog\Handler\StreamHandler('php://stderr', \Monolog\Logger::ERROR, false);
// ...

Logging with Monolog: From Devtools to Slack

preprocessor:

Preprocessor digunakan untuk menambah lebih banyak butiran kepada log. Sebagai contoh,

tambahkan lebih banyak maklumat mengenai permintaan (URL, IP, dan lain -lain).

WebProcessor

Apabila pembalakan, pembalakan akan melalui senarai pemproses berdaftar dan anda akan mendapat maklumat lanjut.
// app/bootstrap/container.php

// ...
$slackHandler = new \Monolog\Handler\SlackHandler('xoxp-5156076911-5156636951-6084570483-7b4fb8', '#general', 'ChhiwatBot');
$logger->pushHandler($slackHandler);

// ...

$slackHandler->setLevel(\Monolog\Logger::ERROR);

Logging with Monolog: From Devtools to Slack Ringkasan:

Monolog adalah salah satu perpustakaan log yang sangat baik dan mengintegrasikan dengan kebanyakan kerangka arus perdana.

FAQ:

(bahagian FAQ ditinggalkan di sini kerana artikel itu terlalu panjang dan mempunyai pengulangan yang tinggi dari kandungan utama artikel. Jika perlu, anda boleh bertanya soalan Soalan Lazim secara berasingan dan saya akan menjawabnya satu persatu.)

Atas ialah kandungan terperinci Pembalakan dengan Monolog: Dari Devtools hingga Slack. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
11 skrip pemendek URL terbaik PHP (percuma dan premium)11 skrip pemendek URL terbaik PHP (percuma dan premium)Mar 03, 2025 am 10:49 AM

URL panjang, sering berantakan dengan kata kunci dan parameter penjejakan, boleh menghalang pelawat. Skrip pemendekan URL menawarkan penyelesaian, mewujudkan pautan ringkas yang sesuai untuk media sosial dan platform lain. Skrip ini sangat berharga untuk laman web individu a

Bekerja dengan Data Sesi Flash di LaravelBekerja dengan Data Sesi Flash di LaravelMar 12, 2025 pm 05:08 PM

Laravel memudahkan mengendalikan data sesi sementara menggunakan kaedah flash intuitifnya. Ini sesuai untuk memaparkan mesej ringkas, makluman, atau pemberitahuan dalam permohonan anda. Data hanya berterusan untuk permintaan seterusnya secara lalai: $ permintaan-

Bina aplikasi React dengan hujung belakang Laravel: Bahagian 2, ReactBina aplikasi React dengan hujung belakang Laravel: Bahagian 2, ReactMar 04, 2025 am 09:33 AM

Ini adalah bahagian kedua dan terakhir siri untuk membina aplikasi React dengan back-end Laravel. Di bahagian pertama siri ini, kami mencipta API RESTful menggunakan Laravel untuk aplikasi penyenaraian produk asas. Dalam tutorial ini, kita akan menjadi dev

Respons HTTP yang dipermudahkan dalam ujian LaravelRespons HTTP yang dipermudahkan dalam ujian LaravelMar 12, 2025 pm 05:09 PM

Laravel menyediakan sintaks simulasi respons HTTP ringkas, memudahkan ujian interaksi HTTP. Pendekatan ini dengan ketara mengurangkan redundansi kod semasa membuat simulasi ujian anda lebih intuitif. Pelaksanaan asas menyediakan pelbagai jenis pintasan jenis tindak balas: Gunakan Illuminate \ Support \ Facades \ http; Http :: palsu ([ 'Google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Curl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API RESTCurl dalam PHP: Cara Menggunakan Pelanjutan PHP Curl dalam API RESTMar 14, 2025 am 11:42 AM

Pelanjutan URL Pelanggan PHP (CURL) adalah alat yang berkuasa untuk pemaju, membolehkan interaksi lancar dengan pelayan jauh dan API rehat. Dengan memanfaatkan libcurl, perpustakaan pemindahan fail multi-protokol yang dihormati, php curl memudahkan execu yang cekap

12 skrip sembang php terbaik di codecanyon12 skrip sembang php terbaik di codecanyonMar 13, 2025 pm 12:08 PM

Adakah anda ingin memberikan penyelesaian segera, segera kepada masalah yang paling mendesak pelanggan anda? Sembang langsung membolehkan anda mempunyai perbualan masa nyata dengan pelanggan dan menyelesaikan masalah mereka dengan serta-merta. Ia membolehkan anda memberikan perkhidmatan yang lebih pantas kepada adat anda

Pengumuman Penyiasatan Situasi PHP 2025Pengumuman Penyiasatan Situasi PHP 2025Mar 03, 2025 pm 04:20 PM

Tinjauan Landskap PHP 2025 menyiasat trend pembangunan PHP semasa. Ia meneroka penggunaan rangka kerja, kaedah penempatan, dan cabaran, yang bertujuan memberi gambaran kepada pemaju dan perniagaan. Tinjauan ini menjangkakan pertumbuhan dalam PHP Versio moden

Pemberitahuan di LaravelPemberitahuan di LaravelMar 04, 2025 am 09:22 AM

Dalam artikel ini, kami akan meneroka sistem pemberitahuan dalam rangka kerja web Laravel. Sistem pemberitahuan di Laravel membolehkan anda menghantar pemberitahuan kepada pengguna melalui saluran yang berbeza. Hari ini, kami akan membincangkan bagaimana anda boleh menghantar pemberitahuan ov

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa