Maison >développement back-end >tutoriel php >linux - log4php在使用过程中提示:配置文件无法加载
下面是一行nginx错误日志,为了便于查看,我给大家做了分隔:
<code>016/08/14 14:34:49 [error] 2819#0: *59 FastCGI sent in stderr: "PHP message: PHP Warning: log4php: Configuration failed. Error loading configuration file: failed to load external entity "/alidata1/****/logger_conf.xml" Using default configuration. in /alidata1/****/configurators/LoggerConfiguratorDefault.php on line 475" while reading response header from upstream, client: 101.226.103.72, server: ****, request: "POST /share/notify HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "*****" </code>情况介绍
1.使用Logger::getRootLogger调用,在入口处,引用Log4php,同时Logger.configure('*')加载。
2.之前没有出现这个问题,我怀疑是因为我调整过一次nginx的权限出现的问题,之前nginx的用户是apache,现在我修改成了nobody。(但是这种怀疑没有依据,我已经重启无数次nginx了)
3.这种情况时好时坏,有的时候我可以正常使用Logger来打印输出,但大多数的时候会报上面的错误。(这从侧面也说明配置文件权限没有问题)。我重启php-fpm有时候会好,但这里面有多少关系,感觉没有任何联系。php-fpm的work进程也是nobody权限
我已经确认可以排除的情况
<code>1. 文件确实存在,文件的权限已经是777.(甚至文件路径中权限我都修改成了777) </code>
有谁遇到了同样的问题,我现在在入口处调用了Logger.configure()来指定调用文件,为啥会出现上面的错误,大家帮忙看一看
下面是一行nginx错误日志,为了便于查看,我给大家做了分隔:
<code>016/08/14 14:34:49 [error] 2819#0: *59 FastCGI sent in stderr: "PHP message: PHP Warning: log4php: Configuration failed. Error loading configuration file: failed to load external entity "/alidata1/****/logger_conf.xml" Using default configuration. in /alidata1/****/configurators/LoggerConfiguratorDefault.php on line 475" while reading response header from upstream, client: 101.226.103.72, server: ****, request: "POST /share/notify HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "*****" </code>情况介绍
1.使用Logger::getRootLogger调用,在入口处,引用Log4php,同时Logger.configure('*')加载。
2.之前没有出现这个问题,我怀疑是因为我调整过一次nginx的权限出现的问题,之前nginx的用户是apache,现在我修改成了nobody。(但是这种怀疑没有依据,我已经重启无数次nginx了)
3.这种情况时好时坏,有的时候我可以正常使用Logger来打印输出,但大多数的时候会报上面的错误。(这从侧面也说明配置文件权限没有问题)。我重启php-fpm有时候会好,但这里面有多少关系,感觉没有任何联系。php-fpm的work进程也是nobody权限
我已经确认可以排除的情况
<code>1. 文件确实存在,文件的权限已经是777.(甚至文件路径中权限我都修改成了777) </code>
有谁遇到了同样的问题,我现在在入口处调用了Logger.configure()来指定调用文件,为啥会出现上面的错误,大家帮忙看一看
问题的解决办法
感谢这篇文章,请点击查看
简短介绍一下问题的原因:引入的类中包含了这个函数:libxml_disable_entity_loader
我的log4php.properties
<code>log4php.rootLogger=INFO, stderr, stdout, file log4php.appender.stdout=LoggerAppenderConsole log4php.appender.stdout.layout=LoggerLayoutPattern log4php.appender.stdout.layout.ConversionPattern=%date{ISO8601} [%p] %m%n log4php.appender.stdout.threshold=INFO log4php.appender.stderr=LoggerAppenderConsole log4php.appender.stderr.layout=LoggerLayoutPattern log4php.appender.stderr.target=stderr log4php.appender.stderr.threshold=ERROR log4php.appender.stderr.layout.ConversionPattern=%date{ISO8601} [%p] [%l] %m%n log4php.appender.file=LoggerAppenderDailyFile log4php.appender.file.layout=LoggerLayoutPattern log4php.appender.file.threshold=ERROR log4php.appender.file.file=commands/logs/%s-error.log log4php.appender.file.layout.ConversionPattern=%date{ISO8601} [%p] [%l] %m%n</code>
PHP初始化
<code>\Logger::configure(__DIR__ . '/log4php.properties'); $logger = \Logger::getLogger('default'); $logger->info('xxx');</code>