Maison >développement back-end >tutoriel php >linux - log4php在使用过程中提示:配置文件无法加载

linux - log4php在使用过程中提示:配置文件无法加载

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBoriginal
2016-08-18 09:16:021342parcourir

下面是一行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()来指定调用文件,为啥会出现上面的错误,大家帮忙看一看

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()来指定调用文件,为啥会出现上面的错误,大家帮忙看一看

linux - log4php在使用过程中提示:配置文件无法加载

问题的解决办法
感谢这篇文章,请点击查看

简短介绍一下问题的原因:引入的类中包含了这个函数: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>
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn