如何使用 Logback 更改 JSON 输出中的键名称?

Mal*_*ych 3 java logging spring logback slf4j

这是我的日志配置。

<springProfile name="prod">
    <root level="info">
        <appender name="naki" class="ch.qos.logback.core.ConsoleAppender">
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>${logging_level}</level> <!-- setup via ENV variable log level -->
            </filter>
            <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
                <layout class="ch.qos.logback.contrib.json.classic.JsonLayout">
                    <timestampFormat>yyyy-MM-dd'T'HH:mm:ss.SSSX</timestampFormat>
                    <timestampFormatTimezoneId>Etc/UTC</timestampFormatTimezoneId>
                    <appendLineSeparator>true</appendLineSeparator> <!-- don't forget line break -->

                    <jsonFormatter class="ch.qos.logback.contrib.jackson.JacksonJsonFormatter">
                        <prettyPrint>false
                        </prettyPrint> <!-- in prod never pretty print, line breaks are considered as separate log entry -->
                    </jsonFormatter>
                </layout>
            </encoder>
        </appender>
    </root>
</springProfile>

<springProfile name="dev">
    <include resource="org/springframework/boot/logging/logback/base.xml"/>
    <root level="info">
        <appender-ref ref="CONSOLE"/>
    </root>
</springProfile>
Run Code Online (Sandbox Code Playgroud)

这是我得到的输出:

{"timestamp":"2020-01-13T13:38:38.001Z","level":"INFO","thread":"main","logger":"com.nakipower.identity.api.config.Application","message":"Started Application in 8.605 seconds (JVM running for 9.439)","context":"default"}
Run Code Online (Sandbox Code Playgroud)

如何将 JSON级别键名称重命名为严重性?所以,我得到的"severity":"INFO"不是"level":"INFO". 在使用 logback 配置日志记录时,我实际上可以重命名 JSON 键名称吗?

Elg*_*yed 8

您可以扩展ch.qos.logback.contrib.jackson.JacksonJsonFormatter和重写toJsonString(Map m)方法。在那里,您可以level使用 key 将给定映射中的条目替换为新条目severity

public class CustomJsonFormatter extends JacksonJsonFormatter{

    @Override
    public String toJsonString(Map map) throws IOException {
        map.put("severity", map.get("level"));
        map.remove("level");
        return super.toJsonString(map);
    }
}
Run Code Online (Sandbox Code Playgroud)

在您的 xml 配置中,在 jsonFormatter 标记中指向您刚刚创建的新格式化程序

<appender name="naki" class="ch.qos.logback.core.ConsoleAppender">
            <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
                <level>INFO</level> <!-- setup via ENV variable log level -->
            </filter>
            <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
                <layout class="ch.qos.logback.contrib.json.classic.JsonLayout">
                    <timestampFormat>yyyy-MM-dd'T'HH:mm:ss.SSSX</timestampFormat>
                    <timestampFormatTimezoneId>Etc/UTC</timestampFormatTimezoneId>
                    <appendLineSeparator>true</appendLineSeparator> <!-- don't forget line break -->

                    <jsonFormatter class="mypackage.CustomJsonFormatter"> <!-- Here point to your custom json formatter -->
                        <prettyPrint>false
                        </prettyPrint> <!-- in prod never pretty print, line breaks are considered as separate log entry -->
                    </jsonFormatter>
                </layout>
            </encoder>
        </appender>
Run Code Online (Sandbox Code Playgroud)