gpt4 book ai didi

log4j - 日志文件在轮换时损坏

转载 作者:行者123 更新时间:2023-12-04 06:27:16 24 4
gpt4 key购买 nike

我正在使用如下的 lo4j.xml 配置文件 -

    <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration debug="true"
xmlns:log4j='http://jakarta.apache.org/log4j/'>

<appender name="console" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{dd.MM.yyyy HH:mm:ss} %-5p %C - %m%n" />
</layout>
</appender>



<appender name="Daily-ROLL-Metric" class="org.apache.log4j.rolling.RollingFileAppender">
<rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
<param name="FileNamePattern"
value="C:/logs/metric.log.%d{yyyy-MM-dd}.gz" />
<param name="ActiveFileName" value="C:/logs/metric.log" />
</rollingPolicy>

<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p (%F:%L) - %m%n" />
</layout>
</appender>


<logger
name="com.tieto.teco.cloudmonitor.mq.listener.SiteScopeMetricsHandler"
additivity="false">
<level value="debug" />
<appender-ref ref="Daily-ROLL-Metric" />
</logger>

<root>
<level value="info" />
<appender-ref ref="Daily-ROLL" />
<appender-ref ref="console" />
</root>


</log4j:configuration>

它第一次正确创建文件,但在第二天轮换文件时,一些损坏的数据被插入到文件中。如果我使用“vi 文件”命令它显示 ^@^@ ^@^@^@^@^@^@^@^@^@^@^@^@^@^@ 字符。

如果我使用 sed 命令显示文件的前 5 行sed -n 1,5p 文件名它不起作用

当我排除第一行时,它会显示正确的日志数据sed -n 2,5p 文件名

看起来,一些二进制数据在旋转时被插入到文件的第一行

需要帮助来解决问题。

最佳答案

我也遇到了这个。我尝试设置属性 append="true",它确实解决了我的问题。

    ...
...
<appender name="Daily-ROLL-Metric" class="org.apache.log4j.rolling.RollingFileAppender" append="true">
...
...

供您引用,我的 appender 如下所示:

<Appenders>

<RollingFile name="ROLL-FILE" fileName="logfilename"
filePattern="logs/application-%d{yyyy-MM-dd}-%i.log"
immediateFlush="false" append="true">
<PatternLayout pattern="%-5p | %d{yyyy-MM-dd HH:mm:ss} | [%t] %C (%F:%L) - %X{unique-id} - %m%n"/>
<Policies>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
</RollingFile>

</Appenders>

关于log4j - 日志文件在轮换时损坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30497952/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com