>백엔드 개발 >PHP 튜토리얼 >awesome PHP之monolog

awesome PHP之monolog

WBOY
WBOY원래의
2016-06-23 13:59:261344검색

monolog是php下比较全又容易扩展的记录日志组件。目前有包括Symfony 、Laravel、 CakePHP等诸多知名php框架都内置了monolog。可以通过github clone https://github.com/Seldaek/monolog.git 或者 composer安装  require monolog/monolog '~1.7'。monolog代码结果如下:

ErrorHandler.php(设置程序的error hander 、exception hander 给mogolog接管)
Formatter/ (内置的日志显示格式)
Handler/ (各种日志处理类,如写文件、发邮件、写socket、写队列等)
Logger.php (log 处理接口)
Processor/ (内置的处理日志类)
Registry.php --


一个例子用在线上错误日志记录上,可以替换默认错误日志的处理方式

[php]  view plain copy

  1. require __DIR__ . '/vendor/autoload.php';  
  2. use Monolog\Logger;  
  3. use Monolog\Handler\StreamHandler;  
  4. use Monolog\Handler\BufferHandler;  
  5. use Monolog\ErrorHandler;  
  6. use Monolog\Processor\MemoryUsageProcessor;  
  7.   
  8.   
  9. $logger = new Logger('error_logger');  
  10. $stream = new StreamHandler(__DIR__.'/error.log', Logger::ERROR);  
  11. $logger->pushHandler(new BufferHandler($stream, 10, Logger::DEBUG, true, true));//用BufferHandler设置同一请求下日志数达到10条再写一次文件  
  12. ErrorHandler::register($logger);  
  13.   
  14. //code...  

monolog完全按照面向对象思想写的,它本身有符合fig的psr-3 prs-4规则,所以扩展起来非常方便,下面是作者文档上写的一个日志入数据库的一个例子

[php]  view plain copy

  1. use Monolog\Logger;  
  2. use Monolog\Handler\AbstractProcessingHandler;  
  3.   
  4. class PDOHandler extends AbstractProcessingHandler  
  5. {  
  6.     private $initialized = false;  
  7.     private $pdo;  
  8.     private $statement;  
  9.   
  10.     public function __construct(PDO $pdo, $level = Logger::DEBUG, $bubble = true)  
  11.     {  
  12.         $this->pdo = $pdo;  
  13.         parent::__construct($level, $bubble);  
  14.     }  
  15.   
  16.     protected function write(array $record)  
  17.     {  
  18.         if (!$this->initialized) {  
  19.             $this->initialize();  
  20.         }  
  21.   
  22.         $this->statement->execute(array(  
  23.             'channel' => $record['channel'],  
  24.             'level' => $record['level'],  
  25.             'message' => $record['formatted'],  
  26.             'time' => $record['datetime']->format('U'),  
  27.         ));  
  28.     }  
  29.   
  30.     private function initialize()  
  31.     {  
  32.         $this->pdo->exec(  
  33.             'CREATE TABLE IF NOT EXISTS monolog '  
  34.             .'(channel VARCHAR(255), level INTEGER, message LONGTEXT, time INTEGER UNSIGNED)'  
  35.         );  
  36.         $this->statement = $this->pdo->prepare(  
  37.             'INSERT INTO monolog (channel, level, message, time) VALUES (:channel, :level, :message, :time)'  
  38.         );  
  39.   
  40.         $this->initialized = true;  
  41.     }  
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.