Heim  >  Artikel  >  Backend-Entwicklung  >  awesome PHP之monolog

awesome PHP之monolog

WBOY
WBOYOriginal
2016-06-23 13:59:261314Durchsuche

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.     }  
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn