Увімкнення для реєстрації різних повідомлень у два файли


146

Я використовую logback / slf4j, щоб зробити свій журнал. Я хочу розібрати свій файл журналу, щоб проаналізувати деякі дані, тому замість розбору великого великого файлу (здебільшого складається з операторів налагодження), я хочу мати два екземпляри реєстратора, кожен журнал яких є окремим файлом; один для аналітики та один для цільового журналу. Хтось знає, чи це можливо за допомогою Logback або будь-якого іншого реєстратора з цього питання?

Відповіді:


296

Зробити щось подібне в режимі автозахисту дуже можливо. Ось приклад конфігурації:

<?xml version="1.0"?>
<configuration>
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>logfile.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger{35} - %msg %n</pattern>
        </encoder>
    </appender>
    <appender name="ANALYTICS-FILE" class="ch.qos.logback.core.FileAppender">
        <file>analytics.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger{35} - %msg %n</pattern>
        </encoder>
    </appender>
    <!-- additivity=false ensures analytics data only goes to the analytics log -->
    <logger name="analytics" level="DEBUG" additivity="false">
        <appender-ref ref="ANALYTICS-FILE"/>
    </logger>
    <root>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

Тоді ви встановите два окремі реєстратори, один на все і один для запису даних аналітики таким чином:

Logger analytics = LoggerFactory.getLogger("analytics");

1
Мені потрібно зробити таку річ, щоб я міг мати додаток без стрічки подачі та звичайне додаток до того ж файлу. Дякую за цю інформацію
djangofan

Додавання IMO = false повинно бути за замовчуванням, якщо вказано інший додаток-ref. Дуже часто ми отримуємо додаток, в якому деякі модулі будуть дуже частими генераторами журналів через деякі події таймера, і ми хотіли б розділити ці журнали на різні файли. Реєструвати один і той же журнал у 10 різних файлах дійсно не має сенсу. Отже, це має бути функція відключення, а не за замовчуванням. Оскільки реєстрація була перезаписаною, той самий автор повинен був виправити той самий автор.
samarjit samanta

Я хочу ввести файли помилок, налагодження, інформаційні повідомлення в різних файлах відповідно. Чи можливо з logback.xml
Qasim

@Qasim - це можливо. Дивіться - amitstechblog.wordpress.com/2014/09/27/…
Енді

Я намагаюся вести журнали з різних пакетів у різні файли, як, наприклад, ця відповідь пропонує, але це не працює для мене. Мій витяг xml виходу тут - pastebin.com/Aii4f1Jk . Я намагаюсь увійти до журналу рівня сну в режимі сну в інший файл. Будь-які пропозиції?
Енді Дуфресне

7

Ви можете мати стільки лісорубів, скільки бажаєте. Але, краще, щоб у вас був один для кожного пакета, який потрібно ввійти по-різному. Тоді всі класи в цьому пакеті та його підпакети отримають саме той реєстратор. Усі вони можуть поділитися кореневим реєстратором та надіслати свої дані журналу кореневому додатку реєстратора, використовуючи additive = "true". Ось приклад:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

<property name="pattern" value="%date{HH:mm:ss.SSS} %-5p %logger{36} 
%X{akkaSource} [%file:%line] - %m%n" />

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%date{HH:mm:ss.SSS} %-5p %logger{36} %X{akkaSource} [%file:%line] - %m%n</pattern>
    </encoder>
</appender>

<appender name="abc" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${catalina.base}/logs/worker.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>${catalina.base}/logs/worker-%d{yyyy-MM-dd_HH}.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>${pattern}</pattern>
    </encoder>
</appender>

<appender name="xyz" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${catalina.base}/logs/transformer.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>${catalina.base}/logs/transformer-%d{yyyy-MM-dd_HH}.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>${pattern}</pattern>
    </encoder>
</appender>

<logger name="com.xxx.yyy.zzz" level="INFO" additivity="true">
    <appender-ref ref="xyz"/>
</logger>

<logger name="com.aaa.bbb.ccc" level="INFO" additivity="true">
    <appender-ref ref="abc"/>
</logger>

<root>
    <level value="INFO" />
    <appender-ref ref="STDOUT" />
</root>


2

у моєму випадку я хотів залишити назви класів як ім’я журналу

private static final Logger log = LoggerFactory.getLogger(ScheduledPost.class);

і як у мене було мало таких занять, так і мій logback.xml

<!--additivity=false ensures this log data only goes to the this log, and no one more -->
<logger name="xxx.xxx.xxx.ScheduledPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.GcmPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.PushUtils" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.