无法将log4j输出到文件



我使用Maven配置文件构建了一个jar,并希望log4j输出重定向到一个文件。

这是我的log4j.properties文件:

# Root logger option
log4j.rootLogger=DEBUG, file
# Direct log messages to a log file
log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=./reporting.log
log4j.appender.file.MaxFileSize=1MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

下面是我从bash运行的命令:

java -jar -Dlog4j.configuration=~/log4j.properties myjar.jar

尽管如此,所有的日志输出都将进入stdout。有什么建议吗?

编辑:

尝试:

  • 在jar的根目录中包含属性文件,默认情况下应该在其中拾取
  • 在运行时指定类路径:-cp
  • 通过maven在清单中添加类路径
  • 在运行时指定属性文件:-Dlog4j.properties=
  • 在运行时指定单个属性:Dlog4j.rootLogger=DEBUG,F-Dlog4j.appender.F=

这些都不起作用——我的想法快用完了。

假设log4j.properties位于运行的/user/home

java -cp /user/home:. -jar myjar.jar
  • 默认情况下,配置文件的名称已经是log4j.properties
  • -Dlog4j.configuration中指定的文件也需要在类路径中

因此,如果您的属性文件是/user/home/temp-log4j.properties,那么您将运行

java -cp /user/home:. -Dlog4j.configuration=temp-log4j.properties -jar myjar.jar

我使用这个配置,也许这个配置可以帮助你,我认为你的问题与路径有关,尝试使用完整的路径,比如FILE.FILE属性中的路径,这是一个绝对路径

log4j.rootLogger = DEBUG, FILE
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=/home/mtataje/logs/repo.log
log4j.appender.FILE.Threshold=debug
log4j.appender.FILE.Append=true
log4j.appender.FILE.MaxFileSize=1MB
log4j.appender.FILE..MaxBackupIndex=2
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

希望它能帮助你,致以最良好的问候。

最新更新