有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java Apache Storm:自定义日志记录

我想修改Storms logback/cluster。xml,以便根据ID写入不同的文件

查看我需要更改群集的信息。xml并添加筛选追加器。参考HERE

主要问题 这是最好/正确的方法吗? 举个例子

我需要补充:

 MDC.put("userid", "Alice");
 logger.debug("Alice says hello");

示例帮助

例如,我似乎无法将其写入文件。我使用默认的logback。类路径中的xml。我不会传入参数并加载配置,因为我假设它会在类路径中找到。但是没有写入文件

<configuration>

<appender name="SIFT" class="ch.qos.logback.classic.sift.SiftingAppender">
    <!-- in the absence of the class attribute, it is assumed that the desired 
        discriminator type is ch.qos.logback.classic.sift.MDCBasedDiscriminator -->
    <discriminator>
        <key>userid</key>
        <defaultValue>unknown</defaultValue>
    </discriminator>
    <sift>
        <appender name="FILE-${userid}" class="ch.qos.logback.core.FileAppender">
            <file>$/Users/Stuart/Desktop/main.log</file>
            <append>false</append>
            <layout class="ch.qos.logback.classic.PatternLayout">
                <pattern>%d [%thread] %level %mdc %logger{35} - %msg%n</pattern>
            </layout>
        </appender>
    </sift>
</appender>

<root level="DEBUG">
    <appender-ref ref="SIFT" />
</root>
</configuration>

共 (1) 个答案

  1. # 1 楼答案

    Apache storm不使用加载日志文件的默认过程。根据您使用的版本,它将为配置文件提供log4jlog4j2或非常简短的logback目录

    您必须修改cluster.xmlworker.xml或两者,以便获得要注册的配置