Home >Backend Development >PHP Tutorial >awesome PHP之monolog

awesome PHP之monolog

WBOY
WBOYOriginal
2016-06-23 13:59:261375browse

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.     }  
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn