monolog是php下比较全又容易扩展的记录日志组件。目前有包括symfony 、laravel、 cakephp等诸多知名php框架都内置了monolog。 monolog可以把你的日志发送到文件,sockets,收件箱,数据库和各种web服务器上。一些特殊的组件可以给你带来特殊的日志策略。 使
monolog是php下比较全又容易扩展的记录日志组件。目前有包括symfony 、laravel、 cakephp等诸多知名php框架都内置了monolog。
monolog可以把你的日志发送到文件,sockets,收件箱,数据库和各种web服务器上。一些特殊的组件可以给你带来特殊的日志策略。
使用例子
1
2
3
4
5
6
7
8
9
10
11
12
pushhandler(newstreamhandler('path/to/your.log', logger::warning));
// add records to the log
$log->addwarning('foo');
$log->adderror('bar');
核心概念
每个logger实例都有一个通道和日志处理器栈。每当你添加一条日志记录,它会被发送到日志处理器栈。 你可以创建很多logger,每个logger定义一个通道(db,请求,路由),每个logger有很多日志处理器。这些通道会过滤日志。
每个日志处理器都有一个formatter(内置的日志显示格式处理器)。你还可以设定日志级别。
日志级别
debug:详细的debug信息info:感兴趣的事件。像用户登录,sql日志notice:正常但有重大意义的事件。warning:发生异常,使用了已经过时的api。error:运行时发生了错误,错误需要记录下来并监视,但错误不需要立即处理。critical:关键错误,像应用中的组件不可用。aletr:需要立即采取措施的错误,像整个网站挂掉了,数据库不可用。这个时候触发器会通过sms通知你,
github 网址https://github.com/seldaek/monolog,官网http://monolog.ow2.org/。