Как настроить параметры для входа в систему, используя класс java вместо файла xml

Я новичок в теме «Журнал» и попытался использовать журнал для регистрации необходимой информации в моем приложении. Я нашел в Интернете, что я могу настроить журнал с помощью файла xml следующим образом:

<springProfile name="production, staging">
        <appender name="debugLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <encoder>
                <pattern>%d %-5level %logger{36} - %msg %n</pattern>
            </encoder>
            <file>logs/service-debug.log</file>

            <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
                <fileNamePattern>logs/service-debug.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <minIndex>1</minIndex>
                <maxIndex>3</maxIndex>
            </rollingPolicy>

            <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
                <maxFileSize>100MB</maxFileSize>
            </triggeringPolicy>

            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>DEBUG</level>
            </filter>
        </appender>

        <appender name="errorLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <encoder>
                <pattern>%d %-5level %logger{36} - %msg %n</pattern>
            </encoder>
            <file>logs/service-error.log</file>

            <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
                <fileNamePattern>logs/service-info.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
                <minIndex>1</minIndex>
                <maxIndex>3</maxIndex>
            </rollingPolicy>

            <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
                <maxFileSize>10MB</maxFileSize>
            </triggeringPolicy>

            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>ERROR</level>
            </filter>
        </appender>

        <root level="DEBUG">
            <appender-ref ref="debugLogAppender" />
            <appender-ref ref="errorLogAppender" />
        </root>
</springProfile>

Я хотел бы зарегистрировать уровень DEBUG и уровень ERROR в двух отдельных файлах. Я проверил с этой конфигурацией, и это сработало!

Но мой вопрос в том, могу ли я сделать ту же конфигурацию, используя класс Java вместо XML-файла, подобного этому. Потому что моя идея заключается в том, что я хочу контролировать конфигурацию журнала извне, также отправляя службу REST в свое приложение для изменения настроек журнала, например: изменить имя файла журнала или изменить шаблон журнала...

Как я могу сделать это с чистым классом Java?

Заранее большое спасибо!


person Bali    schedule 09.11.2018    source источник


Ответы (1)


Я рекомендую прочитать о logback, если я правильно помню, он позволяет вам изменить конфигурацию ведения журнала либо путем изменения файла xml (автоматическая перезагрузка), либо с помощью веб-хука.

person Roy Shahaf    schedule 09.11.2018