Zend \ Log无法创建日志文件

时间:2015-12-12 11:16:22

标签: php zend-framework2 zend-log

我正在学习ZF2并试图使用ZF2建立一个宁静的Web服务架构。我在创建日志文件时遇到问题。

这是我的模块配置:

'service_manager' => array(
    'factories' => array(
        'loggingService' => function(\Zend\ServiceManager\ServiceManager $serviceManager) {
            $logger = new \Zend\Log\Logger();
            $writer = new \Zend\Log\Writer\Stream('/home/mani/logs/forum.log');
            $logger->addWriter($writer);
            return $logger;
        }
    )
)

在这里,我创建了一个logger作为服务,并尝试使用控制器中的构造函数注入logginService。

public function createService(ServiceLocatorInterface $serviceLocator) {

    $coreServiceLocator = $serviceLocator->getServiceLocator();
    $loggingService = $coreServiceLocator->get('loggingService');

    return new QuestionController($loggingService);
}

我认为它会起作用,但ZF2无法创建显示此消息的日志文件:

fopen(/home/mani/logs/forum.log): failed to open stream: No such file or directory

所以我的困惑是ZF2可以创建日志文件还是我们必须手动创建它?

2 个答案:

答案 0 :(得分:0)

在我看来,您有权限问题,例如尝试使用/tmp/app.log更改路径。

由于

答案 1 :(得分:0)

请检查/home/mani/logs是否存在,因为在其他情况下不会创建它并且将抛出相同的错误。同时将777提供给dorectory。