Apache log4J oder doch ein eigener Logger ?

Die Frage ist nicht so einfach zu beantworten denn ein eigener simpler Logger ist relativ schnell geschrieben und verbraucht nur ein drittel der Ressourcen welche der Apache log4j mit der einfachen Einstellung verbraucht.

Wenn also nur fortlaufend in eine *.log Datei ein Wert geschrieben werden soll so kann man sich folgender Klasse behelfen.

Klasse Logger

package de.stefandraegersoftware.simplelogging;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public final class Logger {

	private static Logger instance;

	private static final String LINE_BREAK = "\n";
	private static final String FILENAME_SUFFIX = ".log";
	private static final String FILENAME_DATEFORMAT = "yyyyMMDDHHmmSS";
	private static final String LOGEVENT_DATEFORMAT = "yyyy-MM-dd HH:mm:SS,ss";
	private SimpleDateFormat dateFormatter;

	private File logFile;

	private StringBuffer logBuffer;

	/**
	 * Konstruktor der Klasse Logger
	 */
	private Logger() {
		StringBuffer filenameBuffer = new StringBuffer();
		filenameBuffer.append("./");
		filenameBuffer.append(getFormatedTimestamp(Calendar.getInstance().getTimeInMillis(), FILENAME_DATEFORMAT));
		filenameBuffer.append(FILENAME_SUFFIX);
		logFile = new File(filenameBuffer.toString());
		logBuffer = new StringBuffer();
	}

	/**
	 * Getter Methode um die Instanz der Logger Klasse zu erhalten.
	 * 
	 * @return - die aktuelle Instanz der Logger Klasse
	 */
	public static Logger getInstance() {
		if (instance == null) {
			instance = new Logger();
		}
		return instance;
	}

	/**
	 * Schreibt ein Event in die Loggerklasse.
	 * 
	 * @param lvl
	 *            - {@link Level} Objekt
	 * @param ex
	 *            - {@link Exception} welche geloggt werden soll
	 */
	public void log(Level lvl, Exception ex) {
		long timestamp = Calendar.getInstance().getTimeInMillis();
		storeLogEvent(lvl, ex, timestamp);
	}

	/**
	 * Erstellt ein LogEvent in dem StringBuffer.
	 * 
	 * @param lvl
	 *            - {@link Level} Objekt
	 * @param ex
	 *            - {@link Exception} welche geloggt werden soll
	 * @param timestamp
	 *            - der Zeitstempel wann der Fehler aufgetreten ist
	 */
	private void storeLogEvent(Level lvl, Exception ex, long timestamp) {
		logBuffer.append(String.format("[%s] %s: %s", getFormatedTimestamp(timestamp, LOGEVENT_DATEFORMAT), lvl, ex.getMessage()));
		logBuffer.append(LINE_BREAK);
		for (StackTraceElement element : ex.getStackTrace()) {
			logBuffer.append(element.toString());
			logBuffer.append(LINE_BREAK);
		}
		storeLogBuffer();
	}

	private String getFormatedTimestamp(long timestamp, String dateFormat) {
		dateFormatter = new SimpleDateFormat(dateFormat);
		return dateFormatter.format(timestamp);
	}

	/**
	 * Speichert den StringBuffer in eine Logdatei.
	 */
	private void storeLogBuffer() {
		BufferedWriter bw = null;
		try {
			bw = new BufferedWriter(new FileWriter(logFile));
			bw.write(logBuffer.toString());
			bw.flush();
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			if (bw != null) {
				try {
					bw.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
		}
	}
}

Enum Level

package de.stefandraegersoftware.simplelogging;

public enum Level {
	INFO, DEBUG, WARN, ERROR, FATAL;
}

Klar das ist jetzt ein ganz einfacher Logger aber der reicht in den meisten fällen aus.
Wenn man jetzt größere Anwendungen damit bestücken möchte sollte man sich überlegen ob nicht nach einer bestimmten Größe des StringBuffer Objektes eine neue Logdatei angefangen wird, denn sonst wird das StringBuffer Objekt zum Speicherfresser.

Inhaltsverzeichnis

Download

Schreibe einen Kommentar

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert.