1 安装 composer require monolog/monolog 2 使用 // 创建日志服务 $logger = new Logger('my_logger’); // 定义一个handle $stream = new StreamHandler(__DIR__.'/log/hello.log', Logger::DEBUG); // 设置输出的格式 // 默认的日期格式是 "Y-m-d H:i:s" $dateFormat = "Y n j, g:i a"; // 输出格式 $output = "%datetime% > %level_name% > %message% %context% %extra%\n"; $formatter = new LineFormatter($output, $dateFormat); $stream->setFormatter($formatter); // 把处理器放到对象里面 $this->handles $logger->pushHandler($stream); // 现在你就可以用日志服务了 $logger->info('My logger is now ready',['hello']); // 日志格式 2020 9 25, 9:43 pm > INFO > My logger is now ready ["hello"] {"name":"brady","dummy":"Hello world!"} 3 其他日志格式 按日期 生成 $logger->pushHandler(new \Monolog\Handler\RotatingFileHandler(__DIR__."/log/hello.log",Logger::DEBUG)); //这个会按天产生日志 hello-2020-09-01.log [2020-09-25T21:43:34.047016+08:00] my_logger.INFO: My logger is now ready ["hello"] {"name":"brady","dummy":"Hello world!"} logstash格式 $stream1 = new StreamHandler(__DIR__.'/log/world.log', Logger::DEBUG); $logstashformatter = new \Monolog\Formatter\LogstashFormatter("ml","system","test","world"); $stream1->setFormatter($logstashformatter); $logger->pushHandler($stream1); {"@timestamp":"2020-09-25T21:43:34.047016+08:00","@version":1,"host":"system","message":"My logger is now ready","type":"ml","channel":"my_logger","level":"INFO","monolog_level":200,"test":{"name":"brady","dummy":"Hello world!"},"world":["hello"]} json格式 $stream2 = new \Monolog\Handler\RotatingFileHandler("./log/wang.log"); $json = new \Monolog\Formatter\JsonFormatter(); $stream2->setFormatter($json); $logger->pushHandler($stream2); {"message":"My logger is now ready","context":["hello"],"level":200,"level_name":"INFO","channel":"my_logger","extra":{"name":"brady","dummy":"Hello world!"},"traceId":"trrrrrrrrr","timestamp":"2020-09-25T21:32:47.958836+0800"}ArrayArrayArray{"message":"My logger is now ready","context":["hello"],"level":200,"level_name":"INFO","channel":"my_logger","datetime":"2020-09-25T21:47:27.521873+08:00","extra":{"name":"brady","dummy":"Hello world!"},"traceId":"trrrrrrrrr"} <?php require "./vendor/autoload.php"; error_reporting(E_ALL); ini_set('display_errors', '1'); require __DIR__.'/vendor/autoload.php'; use Monolog\Formatter\LineFormatter; use Monolog\Handler\FirePHPHandler; use Monolog\Logger; use Monolog\Handler\StreamHandler; // 创建日志服务 $logger = new Logger('my_logger'); // 定义一个handle $stream = new StreamHandler(__DIR__.'/log/wei.log', Logger::DEBUG); // 默认的日期格式是 "Y-m-d H:i:s" $dateFormat = "Y n j, g:i a"; // 输出格式 $output = "%datetime% > %level_name% > %message% %context% %extra%\n"; $formatter = new LineFormatter($output, $dateFormat); $stream->setFormatter($formatter); // 把处理器放到对象里面 $this->handles $logger->pushHandler($stream); //第二个处理器 传到hello.log 里面 $logger->pushHandler(new \Monolog\Handler\RotatingFileHandler(__DIR__."/log/hello.log",Logger::DEBUG)); // 处理器 额外的数据给 $logger->pushProcessor(function ($record) { $record['extra']['dummy'] = 'Hello world!'; return $record; }); // 第三个处理器 $stream1 = new StreamHandler(__DIR__.'/log/world.log', Logger::DEBUG); $logstashformatter = new \Monolog\Formatter\LogstashFormatter("ml","system","test","world"); $stream1->setFormatter($logstashformatter); $logger->pushHandler($stream1); //第四个处理器 $stream2 = new \Monolog\Handler\RotatingFileHandler("./log/wang.log"); $json = new \Monolog\Formatter\JsonFormatter(); $stream2->setFormatter($json); $logger->pushHandler($stream2); // 处理器 额外的数据给 $logger->pushProcessor(function ($record) { $record['extra']['name'] = 'brady'; $record['traceId'] = "trrrrrrrrr"; // 好像不行 只能是extra里面 因为record没这个字段 return $record; }); // 现在你就可以用日志服务了 $logger->info('My logger is now ready',['hello']);