Java 在Logback中的多个追加器之间共享一个编码器/模式

Java 在Logback中的多个追加器之间共享一个编码器/模式,java,logging,jakarta-ee,logback,Java,Logging,Jakarta Ee,Logback,这是我第一次涉足LogBack领域,但是我在文档中找不到任何地方可以定义一个编码器/模式并在多个appender之间共享它。你知道如何做到这一点吗?对于任何感兴趣的人,我确实从LogBack的文档中找到了这颗宝石:“每个布局/编码器都与一个且只有一个appender关联,称为拥有appender。”我认为appender不可能共享一个编码器实例 模式可与一起重用 ${defaultPattern} 我一直在以编程方式创建附加器、编码器和布局。我认为上面的说法是正确的:当我试图在appender

这是我第一次涉足LogBack领域,但是我在文档中找不到任何地方可以定义一个编码器/模式并在多个appender之间共享它。你知道如何做到这一点吗?

对于任何感兴趣的人,我确实从LogBack的文档中找到了这颗宝石:“每个布局/编码器都与一个且只有一个appender关联,称为拥有appender。”我认为appender不可能共享一个编码器实例

模式可与一起重用


${defaultPattern}

我一直在以编程方式创建附加器、编码器和布局。我认为上面的说法是正确的:当我试图在appender之间共享编码器时,我只会有一个appender处于活动状态(可能是因为编码器最终只连接到我添加到的最后一个appender)。配置部分也有这一点:请注意,每个appender都有自己的编码器。编码器通常不被设计为由多个附加器共享。布局也是如此。同样地,logback配置文件不提供任何用于共享编码器或布局的语法方法。“这不适用于更复杂的模式,如
%replace(%replace([%X{req.method}%X{req.requestURI}%X{req.queryString}]){'\s+,'}{\[\s\]\s','}
,解决方案是双斜杠。
<configuration>

    <property name="defaultPattern"
        value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n" />

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${defaultPattern}</pattern>
        </encoder>
    </appender>

    <root level="debug">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>