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

下面是一行nginx错误日志,为了便于查看,我给大家做了分隔:

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: "*****"

情况介绍

1.使用Logger::getRootLogger调用,在入口处,引用Log4php,同时Logger.configure(‘*‘)加载。

2.之前没有出现这个问题,我怀疑是因为我调整过一次nginx的权限出现的问题,之前nginx的用户是apache,现在我修改成了nobody。(但是这种怀疑没有依据,我已经重启无数次nginx了)

3.这种情况时好时坏,有的时候我可以正常使用Logger来打印输出,但大多数的时候会报上面的错误。(这从侧面也说明配置文件权限没有问题)。我重启php-fpm有时候会好,但这里面有多少关系,感觉没有任何联系。php-fpm的work进程也是nobody权限

我已经确认可以排除的情况

1. 文件确实存在,文件的权限已经是777.(甚至文件路径中权限我都修改成了777)

有谁遇到了同样的问题,我现在在入口处调用了Logger.configure()来指定调用文件,为啥会出现上面的错误,大家帮忙看一看

bVArHT

问题的解决办法

感谢这篇文章,请点击查看

简短介绍一下问题的原因:引入的类中包含了这个函数:libxml_disable_entity_loader

我的log4php.properties

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

PHP初始化

\Logger::configure(__DIR__ . '/log4php.properties');

$logger = \Logger::getLogger('default');

$logger->info('xxx');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值