我正在使用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级别。)
答案 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请求,以便每个人都可以享受您的工作。