Приложение не записывает журналы при ротации файла журнала - PullRequest
0 голосов
/ 06 мая 2020

Мое приложение использует spring log4j2 и slf4j api для записи журнала в отдельный файл журнала «application.log».

Это приложение развертывается в Tomcat v8 вместе с другими приложениями. Все приложения используют общую конфигурацию log4j2 и записывают в общий файл журнала application.log.

У нас есть политика ротации журналов размером 250 МБ, и при ротации файла журнала журналы не записываются в файл журнала, удивительно только одно приложение Среди всех приложений есть возможность записи в файл журнала.

Я тоже могу воспроизвести это локально. Не могли бы вы помочь в решении этой проблемы.

Другой Пожалуйста, найдите log4j2. xml config ниже.

ВЕРСИИ JAR

  • slf4j- api 1.7.21
  • log4j-slf4j-impl 2.5
  • log4j-api 2.5
  • log4j-core 2.5
  • log4j-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" />

<!-- common package name for all the business application level code -->
     <Logger name="com.trinet" level="info" />

     <!-- Audit Loggger This is used for spring aspect to log before and after execution --> 
     <Logger name="AuditLogger" level="info">
         <AppenderRef ref="AuditLogAsync" />
     </Logger>

     <Root level="info">
         <AppenderRef ref="ApplicationLogAsync" />
     </Root>
 </Loggers>
</Configuration>

1 Ответ

0 голосов
/ 06 мая 2020

Пожалуйста, отредактируйте свой Logger name. Свойству имени регистратора требуется путь к пакету.

КАК ЕСТЬ

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

ДОЛЖНО БЫТЬ

...
<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 Logger и Root Logger. так что вы от additivity до false, тогда он работает каждый.

ссылка на ссылку: Аддитивность

...