Rumah pembangunan bahagian belakang tutorial php Pembalakan dengan Monolog: Dari Devtools hingga Slack

Pembalakan dengan Monolog: Dari Devtools hingga Slack

Feb 17, 2025 am 08:26 AM

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.*'
Salin selepas log masuk
Salin selepas log masuk

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;
Salin selepas log masuk
Salin selepas log masuk

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

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;
Salin selepas log masuk
Salin selepas log masuk
// app/routes.php

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

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.*'
Salin selepas log masuk
Salin selepas log masuk

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;
Salin selepas log masuk
Salin selepas log masuk

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消息。");
Salin selepas log masuk
Salin selepas log masuk

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;
Salin selepas log masuk
Salin selepas log masuk

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消息");
    // ...
});
Salin selepas log masuk
Salin selepas log masuk
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);
// ...
Salin selepas log masuk

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);

// ...
Salin selepas log masuk

$slackHandler->setLevel(\Monolog\Logger::ERROR);
Salin selepas log masuk

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 Laman Web ini
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

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1677
14
Tutorial PHP
1279
29
Tutorial C#
1257
24
Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1? Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1? Apr 17, 2025 am 12:06 AM

Dalam php, kata laluan_hash dan kata laluan 1) password_hash menjana hash yang mengandungi nilai garam untuk meningkatkan keselamatan. 2) Kata Laluan_verify Sahkan kata laluan dan pastikan keselamatan dengan membandingkan nilai hash. 3) MD5 dan SHA1 terdedah dan kekurangan nilai garam, dan tidak sesuai untuk keselamatan kata laluan moden.

Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan? Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan? Apr 17, 2025 am 12:25 AM

Jenis PHP meminta untuk meningkatkan kualiti kod dan kebolehbacaan. 1) Petua Jenis Skalar: Oleh kerana Php7.0, jenis data asas dibenarkan untuk ditentukan dalam parameter fungsi, seperti INT, Float, dan lain -lain. 2) Return Type Prompt: Pastikan konsistensi jenis nilai pulangan fungsi. 3) Jenis Kesatuan Prompt: Oleh kerana Php8.0, pelbagai jenis dibenarkan untuk ditentukan dalam parameter fungsi atau nilai pulangan. 4) Prompt jenis yang boleh dibatalkan: membolehkan untuk memasukkan nilai null dan mengendalikan fungsi yang boleh mengembalikan nilai null.

PHP dan Python: Paradigma yang berbeza dijelaskan PHP dan Python: Paradigma yang berbeza dijelaskan Apr 18, 2025 am 12:26 AM

PHP terutamanya pengaturcaraan prosedur, tetapi juga menyokong pengaturcaraan berorientasikan objek (OOP); Python menyokong pelbagai paradigma, termasuk pengaturcaraan OOP, fungsional dan prosedur. PHP sesuai untuk pembangunan web, dan Python sesuai untuk pelbagai aplikasi seperti analisis data dan pembelajaran mesin.

Memilih antara php dan python: panduan Memilih antara php dan python: panduan Apr 18, 2025 am 12:24 AM

PHP sesuai untuk pembangunan web dan prototaip pesat, dan Python sesuai untuk sains data dan pembelajaran mesin. 1.Php digunakan untuk pembangunan web dinamik, dengan sintaks mudah dan sesuai untuk pembangunan pesat. 2. Python mempunyai sintaks ringkas, sesuai untuk pelbagai bidang, dan mempunyai ekosistem perpustakaan yang kuat.

PHP dan Python: menyelam mendalam ke dalam sejarah mereka PHP dan Python: menyelam mendalam ke dalam sejarah mereka Apr 18, 2025 am 12:25 AM

PHP berasal pada tahun 1994 dan dibangunkan oleh Rasmuslerdorf. Ia pada asalnya digunakan untuk mengesan pelawat laman web dan secara beransur-ansur berkembang menjadi bahasa skrip sisi pelayan dan digunakan secara meluas dalam pembangunan web. Python telah dibangunkan oleh Guidovan Rossum pada akhir 1980 -an dan pertama kali dikeluarkan pada tahun 1991. Ia menekankan kebolehbacaan dan kesederhanaan kod, dan sesuai untuk pengkomputeran saintifik, analisis data dan bidang lain.

PHP dan Rangka Kerja: Memodenkan bahasa PHP dan Rangka Kerja: Memodenkan bahasa Apr 18, 2025 am 12:14 AM

PHP tetap penting dalam proses pemodenan kerana ia menyokong sejumlah besar laman web dan aplikasi dan menyesuaikan diri dengan keperluan pembangunan melalui rangka kerja. 1.Php7 meningkatkan prestasi dan memperkenalkan ciri -ciri baru. 2. Rangka kerja moden seperti Laravel, Symfony dan CodeIgniter memudahkan pembangunan dan meningkatkan kualiti kod. 3. Pengoptimuman prestasi dan amalan terbaik terus meningkatkan kecekapan aplikasi.

Mengapa menggunakan PHP? Kelebihan dan faedah dijelaskan Mengapa menggunakan PHP? Kelebihan dan faedah dijelaskan Apr 16, 2025 am 12:16 AM

Manfaat utama PHP termasuk kemudahan pembelajaran, sokongan pembangunan web yang kukuh, perpustakaan dan kerangka yang kaya, prestasi tinggi dan skalabilitas, keserasian silang platform, dan keberkesanan kos. 1) mudah dipelajari dan digunakan, sesuai untuk pemula; 2) integrasi yang baik dengan pelayan web dan menyokong pelbagai pangkalan data; 3) mempunyai rangka kerja yang kuat seperti Laravel; 4) Prestasi tinggi dapat dicapai melalui pengoptimuman; 5) menyokong pelbagai sistem operasi; 6) Sumber terbuka untuk mengurangkan kos pembangunan.

Impak PHP: Pembangunan Web dan seterusnya Impak PHP: Pembangunan Web dan seterusnya Apr 18, 2025 am 12:10 AM

Phphassignificantelympactedwebdevelopmentandextendsbeyondit.1) itpowersmajorplatformslikeworderpressandexcelsindatabaseIntions.2) php'SadaptabilityAldoStoScaleforlargeapplicationFrameworksLikelara.3)

See all articles