Javaロギング出力を1行に表示するにはどうすればよいですか?


Answers

1) -Djava.util.logging.SimpleFormatter.format

Java 7はjava.util.Formatter形式の文字列構文を持つプロパティをサポートしています。

-Djava.util.logging.SimpleFormatter.format=... 

here参照してhere

私のお気に入りは:

-Djava.util.logging.SimpleFormatter.format=%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS %4$-6s %2$s %5$s%6$s%n

出力は次のようになります。

2014-09-02 16:44:57 SEVERE org.jboss.windup.util.ZipUtil unzip: Failed to load: foo.zip

2)それをIDEに配置する

IDEでは、通常、プロジェクトのシステムプロパティを設定できます。 たとえば、NetBeansの場合、-D ... = ...をどこかに追加する代わりに、 java.util.logging.SimpleFormatter.format=%1$tY-%1$tm-... - 引用符なし。 IDEは把握する必要があります。

3)それをMavenに置く - Surefire

あなたの便宜のために、ここにSurefireを置く方法があります:

        <!-- Surefire -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>2.17</version>
            <configuration>
                <systemPropertyVariables>
                    <!-- Set JUL Formatting -->
                    <java.util.logging.SimpleFormatter.format>%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS %4$-6s %2$s %5$s%6$s%n</java.util.logging.SimpleFormatter.format>
                </systemPropertyVariables>
            </configuration>
        </plugin>

4)手作り

java.util.logging関連のクラスほとんどないライブラリがあります 。 その中で、 SingleLineFormatterです。 hereダウンロード可能な瓶。

public class SingleLineFormatter extends Formatter {

  Date dat = new Date();
  private final static String format = "{0,date} {0,time}";
  private MessageFormat formatter;
  private Object args[] = new Object[1];

  // Line separator string.  This is the value of the line.separator
  // property at the moment that the SimpleFormatter was created.
  //private String lineSeparator = (String) java.security.AccessController.doPrivileged(
  //        new sun.security.action.GetPropertyAction("line.separator"));
  private String lineSeparator = "\n";

  /**
   * Format the given LogRecord.
   * @param record the log record to be formatted.
   * @return a formatted log record
   */
  public synchronized String format(LogRecord record) {

    StringBuilder sb = new StringBuilder();

    // Minimize memory allocations here.
    dat.setTime(record.getMillis());    
    args[0] = dat;


    // Date and time 
    StringBuffer text = new StringBuffer();
    if (formatter == null) {
      formatter = new MessageFormat(format);
    }
    formatter.format(args, text, null);
    sb.append(text);
    sb.append(" ");


    // Class name 
    if (record.getSourceClassName() != null) {
      sb.append(record.getSourceClassName());
    } else {
      sb.append(record.getLoggerName());
    }

    // Method name 
    if (record.getSourceMethodName() != null) {
      sb.append(" ");
      sb.append(record.getSourceMethodName());
    }
    sb.append(" - "); // lineSeparator



    String message = formatMessage(record);

    // Level
    sb.append(record.getLevel().getLocalizedName());
    sb.append(": ");

    // Indent - the more serious, the more indented.
    //sb.append( String.format("% ""s") );
    int iOffset = (1000 - record.getLevel().intValue()) / 100;
    for( int i = 0; i < iOffset;  i++ ){
      sb.append(" ");
    }


    sb.append(message);
    sb.append(lineSeparator);
    if (record.getThrown() != null) {
      try {
        StringWriter sw = new StringWriter();
        PrintWriter pw = new PrintWriter(sw);
        record.getThrown().printStackTrace(pw);
        pw.close();
        sb.append(sw.toString());
      } catch (Exception ex) {
      }
    }
    return sb.toString();
  }
}
Question

現時点では、デフォルトのエントリは次のようになります。

Oct 12, 2008 9:45:18 AM myClassInfoHere
INFO: MyLogMessageHere

これをするにはどうしたらいいですか?

Oct 12, 2008 9:45:18 AM myClassInfoHere - INFO: MyLogMessageHere

私はjava.util.loggingを使用しています




java.util.loggingを使用している場合は、プログラム設定を使用している場合を除いて、内容を記録するための設定ファイルがあります。 だから、あなたのオプションは
1)改行を削除するポストプロセッサを実行する
2)ログの設定を変更し、そこから改行を削除します。 アプリケーション(サーバー)を再起動すると、正常に動作するはずです。




Obediah Stane氏のように、独自のformatメソッドを作成する必要があります。 しかし、私はいくつかのことを変えるだろう:

  • SimpleFormatterからではなく、 Formatterから直接派生したサブクラスを作成します。 SimpleFormatterは何も追加するSimpleFormatterはありません。

  • 新しいDateオブジェクトの作成には注意してください。 LogRecord日付を必ず表示するようにしてください。 デフォルトのコンストラクタで新しいDateを作成すると、 LogRecordが作成された日付ではなく、 FormatterLogRecord処理する日時が表示されます。

次のクラスはHandler内のフォーマッタとして使用でき、 Handlerは次にLogger addedできます。 LogRecord利用可能なクラスとメソッドの情報はすべて無視されることに注意してください。

import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.Date;
import java.util.logging.Formatter;
import java.util.logging.LogRecord;

public final class LogFormatter extends Formatter {

    private static final String LINE_SEPARATOR = System.getProperty("line.separator");

    @Override
    public String format(LogRecord record) {
        StringBuilder sb = new StringBuilder();

        sb.append(new Date(record.getMillis()))
            .append(" ")
            .append(record.getLevel().getLocalizedName())
            .append(": ")
            .append(formatMessage(record))
            .append(LINE_SEPARATOR);

        if (record.getThrown() != null) {
            try {
                StringWriter sw = new StringWriter();
                PrintWriter pw = new PrintWriter(sw);
                record.getThrown().printStackTrace(pw);
                pw.close();
                sb.append(sw.toString());
            } catch (Exception ex) {
                // ignore
            }
        }

        return sb.toString();
    }
}



スクリーンショットごとに、Eclipseで「run as」を選択してから「Run Configurations ...」を選択し、Trevor Robinsonの回答を引用符ではなく二重引用符で追加します。 二重引用符が見つからない場合は、「メインクラスを見つけたり読み込めませんでした」というエラーが表示されます。




このロギングは、アプリケーション固有のものであり、一般的なJava機能ではありません。 どのアプリケーションを実行していますか?

これは、独自のコード内で使用している特定のロギングライブラリからのものである可能性があります。 もしそうなら、あなたが使っているものの詳細を投稿してください。