• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-23) 15次浏览 已收录 0个评论
文章目录[隐藏]

<body>

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

回复内容:

<body>

下面是一行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, filelog4php.appender.stdout=LoggerAppenderConsolelog4php.appender.stdout.layout=LoggerLayoutPatternlog4php.appender.stdout.layout.ConversionPattern=%date{ISO8601} [%p] %m%nlog4php.appender.stdout.threshold=INFOlog4php.appender.stderr=LoggerAppenderConsolelog4php.appender.stderr.layout=LoggerLayoutPatternlog4php.appender.stderr.target=stderrlog4php.appender.stderr.threshold=ERRORlog<strong>+本文来源gao@daima#com搞(%代@#码网</strong><pre>搞代gaodaima码

4php.appender.stderr.layout.ConversionPattern=%date{ISO8601} [%p] [%l] %m%nlog4php.appender.file=LoggerAppenderDailyFilelog4php.appender.file.layout=LoggerLayoutPatternlog4php.appender.file.threshold=ERRORlog4php.appender.file.file=commands/logs/%s-error.loglog4php.appender.file.layout.ConversionPattern=%date{ISO8601} [%p] [%l] %m%n

PHP初始化

<code>\Logger::configure(__DIR__ . '/log4php.properties');$logger = \Logger::getLogger('default');$logger->info('xxx');</code>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:linux – log4php在使用过程中提示:配置文件无法加载

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址