平舟/monolog

这是monolog包的扩展

v1.02 2022-01-11 09:03 UTC

This package is auto-updated.

Last update: 2024-09-12 08:33:04 UTC


README

安装

您可以使用Composer将此库添加为项目的本地依赖

composer require pianzhou/monolog

一、数据库处理器介绍

首先需要创建数据表,以MySQL为例

CREATE TABLE IF NOT EXISTS `t_logs` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `message` text NOT NULL,
  `channel` varchar(20) NOT NULL,
  `level_name` varchar(20) NOT NULL,
  `level` smallint(6) NOT NULL,
  `context` text NOT NULL,
  `extra` text NOT NULL,
  `datetime` timestamp NULL DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
COMMIT;

目前Database Handler支持PDO实例和laravel ConnectionInterface实例

1、PDO实例使用方法:

$dbHandler     = new \Pianzhou\Monolog\Handler\DatabaseHandler(
    new PDO('mysql:host=localhost;dbname=test', 'root', ''),
    't_logs',
    \Monolog\Logger::DEBUG,
    true
 );

 $dbHandler->setFormatter(new \Pianzhou\Monolog\Formatter\TransformScalarFormatter());

 $logger    = new \Monolog\Logger('测试', [
     $dbHandler,
 ]);

$logger->info('测试一下写入数据库');

2、laravel ConnectionInterface实例使用方法(需要安装依赖:illuminate/database)

$dbHandler     = new \Pianzhou\Monolog\Handler\DatabaseHandler(
    new Illuminate\Database\MySqlConnection(
      new PDO('mysql:host=localhost;dbname=test', 'root', '')
    ),
    't_logs',
    \Monolog\Logger::DEBUG,
    true
 );

 $dbHandler->setFormatter(new \Pianzhou\Monolog\Formatter\TransformScalarFormatter());

 $logger    = new \Monolog\Logger('测试', [
     $dbHandler,
 ]);

$logger->info('测试一下写入数据库');

通过上面的示例,我们可以轻松地将日志文件记录到数据库中。另外,如果使用BufferHandler批量写入日志,DatabaseHandler将一次性批量写入日志到数据库,而不是逐条记录。

相关链接:

基于PHP Monolog,打造数据库日志记录器(DatabaseHandler)

基于PHP Monolog,打造一个API请求日志记录器