应用程序在日志文件旋转时不写日志

问题描述 投票:0回答:1

我的应用程序正在使用spring log4j2,并使用slf4j api将日志写入单独的日志文件“ application.log”。该应用程序与其他应用程序一起部署到了tomcat v8。所有应用共享通用的log4j2配置,并写入通用日志文件“ application.log”。我们有250 mb的日志轮换策略,当日志文件轮换时,日志没有写入日志文件,这令人惊讶,所有应用程序中只有一个能够写入日志文件。我也可以在本地复制。您能帮忙解决此问题吗?请在下面找到log4j2.xml配置。

JAR版本slf4j-api 1.7.21log4j-slf4j-impl 2.5log4j-api 2.5log4j核心2.5log4j-web 2.5

Log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration name="api-config" status="trace" monitorInterval="30">
  <Properties>
    <Property name="logdir">/Users/kramesan/microservices-config/logs</Property>
  </Properties>
  <Appenders>

    <Console name="STDOUT" target="SYSTEM_OUT">
      <PatternLayout pattern="%X{_requestId} %X{authToken} %X{urlEmployeeId} %X{urlCompanyId} [%X{authEmplIds}] [%X{authCompanyIds}] %d{yyy
y-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n"/>
    </Console>

    <RollingFile name="ApplicationLogRollingFile" fileName="${logdir}/application.log"
      filePattern="${logdir}/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz">
      <JSONLayout locationInfo="true" complete="true" compact="true" eventEol="true" properties="true" />
      <Policies>
        <TimeBasedTriggeringPolicy />
        <SizeBasedTriggeringPolicy size="250 MB" />
      </Policies>
      <DefaultRolloverStrategy max="20" />
    </RollingFile>

    <RollingFile name="AuditLogRollingFile" fileName="${logdir}/audit/api-audit.log"
      filePattern="${logdir}/audit/$${date:yyyy-MM}/api-audit-%d{MM-dd-yyyy}-%i.log.gz">
      <PatternLayout>
            <Pattern>%X{_requestId} %X{authToken} %X{urlEmployeeId} %X{urlCompanyId} [%X{authEmplIds}] [%X{authCompanyIds}] %m%n</Pattern>
      </PatternLayout>
      <!-- JSONLayout locationInfo="true" complete="true" compact="true" eventEol="true" properties="true" -->
      <Policies>
        <TimeBasedTriggeringPolicy />
        <SizeBasedTriggeringPolicy size="250 MB" />
      </Policies>
      <DefaultRolloverStrategy max="20" />
    </RollingFile>
        <Async name="ApplicationLogAsync" bufferSize="262144">
         <AppenderRef ref="ApplicationLogRollingFile"/>
     </Async>

     <Async name="AuditLogAsync" bufferSize="262144">
         <AppenderRef ref="AuditLogRollingFile"/>
     </Async>

 </Appenders>
 <Loggers>
     <!--  All the 3rd Party frameworks -->
     <Logger name="org.springframework" level="warn" />

     <Logger name="org.hibernate" level="warn" />


     <Logger name="com.companyname" level="info" />

     <!-- Audit Loggger -->
     <Logger name="AuditLogger" level="info">
         <AppenderRef ref="AuditLogAsync" />
     </Logger>

     <Root level="info">
         <AppenderRef ref="ApplicationLogAsync" />
     </Root>
 </Loggers>
</Configuration>
spring log4j2 slf4j tomcat8
1个回答
0
投票

请编辑您的Logger name。记录器名称属性需要包路径。

AS-IS

...
<Logger name="AuditLogger" level="info">
...

TO-BE

...
<Logger name="com.foo.bar.AuditLogger" level="info" additivity="false">
...

...
<Logger name="com.foo.bar.*" level="info" additivity="false">
...

我认为您最好写入属性additivity,因为您的Logger工作两次是com.foo.bar.AuditLogger LoggerRoot Logger。因此,您将additivity设置为false,然后每个都可以使用。

参考链接:Additivity

© www.soinside.com 2019 - 2024. All rights reserved.