平舟 / monolog
这是monolog包的扩展
v1.02
2022-01-11 09:03 UTC
Requires
- php: >=7.2
- monolog/monolog: ^2.0
Provides
- psr/log-implementation: 1.0.0 || 2.0.0 || 3.0.0
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将一次性批量写入日志到数据库,而不是逐条记录。
相关链接: