Silex的默认Monolog消息

时间:2013-12-12 23:29:40

标签: silex monolog

我正在使用Silex 1.1和Monolog 1.0.0。我的代码和我的问题:

$app->register(new Silex\Provider\MonologServiceProvider(), array(
  'monolog.name' => 'myname',
  'monolog.logfile' => ROOT . '/logs/log.txt',
  'monolog.level'   => Monolog\Logger::INFO
));

. . .
$app['monolog']->addInfo('xxx');

一切正常,但我收到如下默认消息:

[2013-12-13 00:20:56] myname.INFO: Matched route "GET_api_v1_predictions" (parameters: "_controller": "predictions.controller:index", "_route": "GET_api_v1_predictions") [] []
[2013-12-13 00:20:56] myname.INFO: > GET /api/v1/predictions [] []

我如何禁用它们? (如果我将日志记录级别更改为WARNING并使用addWarning,则只显示我的消息,但我想使用INFO级别。)

2 个答案:

答案 0 :(得分:6)

您仍然可以为您的应用程序创建一个未被其他进程使用的记录器:

use Monolog\Logger;
use Monolog\Handler\StreamHandler;

// initialize the logger
$app['mylog'] = $app->share(function($app) {
   return new Logger('mylog');
});
$app['mylog']->pushHandler(new StreamHandler('/logfile/mylog.log', Logger::INFO));
$app['mylog']->addInfo('Private Log initialized');

答案 1 :(得分:1)

目前there's no way to disable them,无条件注册日志命令。

短期解决方案是将MonologServiceProvider复制到您自己的应用程序中,根据需要更改日志命令。

长期解决方案是分叉silex存储库,更改MonologServiceProvider以提供禁用这些命令的方法,然后创建一个pull请求,以便每个人都可以享受您的工作。