1

特定のパターンを使用して log4j2 ログを書き込もうとしています。

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout charset="UTF-8"
                pattern="%d{HH:mm:ss.SSS} ${main:-jobId} %-5.-5level %-25.-25c{1}%-25.-25method(%5.5line) - %msg%n" />
        </Console>
        <RollingFile name="LogFile" fileName="${sys:logFile}"
            filePattern="${sys:logFile}-%d{MM-dd-yyyy}-%i.log.gz">
            <PatternLayout charset="UTF-8"
                pattern="%d{yyy-MM-dd HH:mm:ss.SSS} ${main:-jobId} [%-30.-30t] %-5.-5level %-25.-25c{1}%-25.-25method(%5.5line) - %msg%n" />
            <Policies>
                <TimeBasedTriggeringPolicy />
                <SizeBasedTriggeringPolicy size="100 MB" />
            </Policies>
        </RollingFile>
    </Appenders>
    <Loggers>
        <Root level="trace">
            <AppenderRef ref="LogFile" level="debug" />
            <AppenderRef ref="Console" level="info" />
        </Root>
    </Loggers>
</Configuration>

いくつかの引数を渡しています -o abc -d def -jobId 1234 -DlogFile /usr/lib/logpath.log これはシステム パラメータに対して機能しますが、ログは次のように出力されます。

15:33:34.889 jobId INFO  Test           main                     (   74) - -b
15:33:34.890 jobId INFO  Test           main                     (   74) - -o
15:33:34.890 jobId INFO  Test           main                     (   74) - account
15:33:34.890 jobId INFO  Test           main                     (   74) - document
15:33:34.890 jobId INFO  Test           main                     (   74) - -d
15:33:34.891 jobId INFO  Test           main                     (   74) - rest
15:33:34.891 jobId INFO  Test           main                     (   74) - -l
15:33:34.891 jobId INFO  Test           main                     (   74) - 100
15:33:34.891 jobId INFO  Test           main                     (   74) - -skipmd
15:33:34.891 jobId INFO  Test           main                     (   74) - -db
15:33:34.891 jobId INFO  Test           main                     (   74) - -jobId
15:33:34.891 jobId INFO  Test           main                     (   74) - 1234

main のコードは次で始まります。

public static void main(String[] args) throws Exception
    {
        MainMapLookup.setMainArguments(args);
        for (String s : args)
            logger.info(s);
...
}

インデックスに基づいて引数を使用してみましたが、機能します。ただし、主な引数のルックアップは機能していないようです。ここで何か不足していますか?

トピック外の質問かもしれませんが、ロギングの主な引数に対してシステム変数を処理する正当なユースケースは何ですか?

4

1 に答える 1