最新下载
24小时阅读排行榜
- 1 php按括号分割文本_php括号分割正则捕获内容【技巧】
- 2 如何在 PhpSpreadsheet 中正确设置单元格为百分比格式
- 3 Go语言返回指针是否安全_Golang逃逸分析基础说明
- 4 Linux 日志轮转 logrotate 的正确配置方式
- 5 C++ 字符串怎么拼接 C++ string加号运算符重载原理【操作】
- 6 php实时输出配合sse怎么做_php实时输出sse推送教程【教程】
- 7 Golang高并发场景下如何减少GC压力_Golang GC调优实战
- 8 C++ 怎么获取文件大小 C++ filesystem file_size函数用法【C++17】
- 9 SQL 如何处理“闰年/闰月”导致的日期计算错误
- 10 后代选择器与子选择器有什么区别_选择元素的层级控制技巧
- 11 C++ new和malloc区别 C++ 构造函数调用与类型安全对比【基础】
- 12 如何使用Golang实现文件加密与解密_Golang crypto包操作示例
- 13 Go语言如何实现命令行工具_Golang CLI项目实战教程
- 14 如何在Golang中处理网络请求错误_Golang网络请求错误处理与重试机制
- 15 css浮动导航菜单点击区域小怎么办_调整padding或增加clear
最新教程
-
- Node.js 教程
- 16344 2025-08-28
-
- CSS3 教程
- 1547059 2025-08-27
-
- Rust 教程
- 23462 2025-08-27
-
- Vue 教程
- 25892 2025-08-22
-
- PostgreSQL 教程
- 22389 2025-08-21
-
- Git 教程
- 9333 2025-08-21
Monolog是php下比较全又容易扩展的记录日志类库。目前有包括Symfony 、Laravel、 CakePHP等诸多知名php框架都内置了Monolog。Monolog可以把你的日志发送到文件,sockets,收件箱,数据库和各种web services。
Monolog遵循PSR3的接口规范,可以很轻易的替换成其他遵循同一规范的日志类库。Monolog具有良好的扩展性,通过Handler、Formatter和Processor这几个接口,可以对Monolog类库进行各种扩展和自定义。
基本用法
<?php
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
// 创建日志频道
$log = new Logger('name');
$log->pushHandler(new StreamHandler('path/to/your.log', Logger::WARNING));
// 添加日志记录
$log->addWarning('Foo');
$log->addError('Bar');核心概念
每一个Logger实例都包含一个频道名(channel)和handler的堆栈。当你添加一条记录时,记录会依次通过handler堆栈的处理。而每个handler也可以决定是否把记录传递到下一个堆栈里的下一个handler。
通过handler,我们可以实现一些复杂的日志操作。例如我们把StreamHandler放在堆栈的最下面,那么所有的日志记录最终都会写到硬盘文件里。同时我们把MailHandler放在堆栈的最上面,通过设置日志等级把错误日志通过邮件发送出去。Handler里有个$bubble属性,这个属性定义了handler是否拦截记录不让它流到下一个handler。所以如果我们把MailHandler的$bubble参数设置为false,则出现错误日志时,日志会通过MailHandler发送出去,而不会经过StreamHandler写到硬盘上。
Logger可以创建多个,每个都可以定义自己的频道名和handler堆栈。handler可以在多个Logger中共享。频道名会反映在日志里,方便我们查看和过滤日志记录。
如果没有指定日志格式(Formatter),Handler会使用默认的Formatter。
日志的等级不能自定义,目前使用的是RFC 5424里定义的8个等级:debug、info、notice、warning、error、critical、alert和emergency。如果对日志记录有其他的需求,可以通过Processo对日志记录添加内容。
日志等级
DEBUG (100): 详细的debug信息。
INFO (200): 关键事件。
NOTICE (250): 普通但是重要的事件。
WARNING (300): 出现非错误的异常。
ERROR (400): 运行时错误,但是不需要立刻处理。
CRITICA (500): 严重错误。
EMERGENCY (600): 系统不可用。
