我的程序在一些Linux机器上作为服务运行。我发现在Ubuntu 16日志记录上是可以的,但是在CentOS (LinuxLocal3.10.0-514.21.1.el7.x86_64 #1 SMP清华5月25日17:04:51 UTC 2017 x86_64 GNU/Linux)上,我没有观察到在/var/log中创建的日志文件。
Log4j2配置
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
</Console>
<RollingFile name="InfoFileAppender"
fileName="/var/log/MY.log"
filePattern="/var/log/MY.log.%d{yyyy-MM-dd-hh-mm}.gz">
<PatternLayout pattern="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="100 MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingFile>
</Appenders>
<Loggers>
<Root level="INFO">
<AppenderRef ref="Console" level="TRACE"/>
<AppenderRef ref="InfoFileAppender" level="TRACE"/>
</Root>
</Loggers>
</Configuration>
然而,当我运行sudo服务我的服务状态时,我确实看到了几行日志--所以它们必须到达其他地方!
据我猜测,日志可能会显示一些日志,并使用https://www.loggly.com/ultimate-guide/using-journalctl/获取一些日志跟踪命令,但是对于任何结果,它都会回答“找不到日志文件”。
我怎么能解决这个问题?
发布于 2017-07-11 07:02:02
在我看来,这似乎是一个许可问题。您应该给予/var/log的用户写权限。
https://stackoverflow.com/questions/45027438
复制相似问题