【发布时间】:2018-11-24 20:30:53
【问题描述】:
我正在尝试使用新的 laravel 5.6 版的通道制作自定义日志,但我无法实现它。我已经安装了最新版本的独白。如何使用 MongoDBHandler 的独白将记录保存在我的 MongoDB 银行中。
我正在尝试添加自定义频道,但它不起作用。
namespace Monolog\Handler;
use Monolog\Logger;
use Monolog\Formatter\NormalizerFormatter;
/**
* Logs to a MongoDB database.
*
* usage example:
*
* $log = new Logger('application');
* $mongodb = new MongoDBHandler(new \Mongo("mongodb://localhost:27017"), "logs", "prod");
* $log->pushHandler($mongodb);
*
* @author Thomas Tourlourat <thomas@tourlourat.com>
*/
class MongoDBHandler extends AbstractProcessingHandler
{
protected $mongoCollection;
public function __construct($mongo, $database, $collection, $level = Logger::DEBUG, $bubble = true)
{
if (!($mongo instanceof \MongoClient || $mongo instanceof \Mongo || $mongo instanceof \MongoDB\Client)) {
throw new \InvalidArgumentException('MongoClient, Mongo or MongoDB\Client instance required');
}
$this->mongoCollection = $mongo->selectCollection($database, $collection);
parent::__construct($level, $bubble);
}
protected function write(array $record)
{
if ($this->mongoCollection instanceof \MongoDB\Collection) {
$this->mongoCollection->insertOne($record["formatted"]);
} else {
$this->mongoCollection->save($record["formatted"]);
}
}
protected function getDefaultFormatter()
{
return new NormalizerFormatter();
}
}
【问题讨论】:
-
当我登录我的应用程序时(Log::info(
access, $variables))我想通过渠道插入 mongo -
"但它不工作" => 你遇到什么错误?你的 config/log.php 配置是什么?
标签: mongodb laravel-5.6 monolog