OOP java.util.logging.Logger: Wie kann ich mehre Klassen in ein Logfile schreiben lassen?

backarc

Mitglied
Wie kann ich von mehreren Klassen aus einen Logger nutzen?

Aktuell habe ich in jeder Klasse eine eigene Logger-Instanz.
Deshalb erstellt mein Programm eine ganze Menge log-Dateien. Ist natürlich schön fürs debuggen, aber schöner wäre eine Log-Datei.
Ich möchte so weit wie möglich auf externe Bibliotheken verzichten um in jedem Fall auf Windows und MacOS lauffähig zu sein, deshalb nutze ich java.util.logging.Logger.

Jetzt mag ich einfach zu blöde sein, oder nicht genügend von Java verstehen - aber ich bekomme das irgendwie nicht hin.
Sinnvolle Beispiele finde ich nicht - entweder das macht niemand, niemand nutzt Logger (eventuell mit log4J?) oder ich nutze die falschen Suchbegriffe.



Was ich bisher versucht habe, ist eine Klasse zu bauen.
1) Die von Logger abgelitten ist. Hat nicht funktioniert, finde keinen Weg das "legal" hinzubekommen.
2) Die eine Instanz von Logger enthält. Wenn ich dann eine Instanz der Klasse in anderen Klassen nutze schreibt er mir dann leider keine Daten in die Logs.
3) Einfach so denselben Dateinamen nutzen - geht nicht, Java macht einen Filelock auf das Logfile.


Jetzt die Frage(n):
Kann man das hinbekommen?
Wenn ja wie?
Gibt es Tutorials oder andere Quellen (gerne auch in Englisch) die das Beschreiben?

Danke für Eure Hilfe im voraus!

Gruss,

backarc
 

turtle

Top Contributor
Kann man das hinbekommen?
Ja
Wenn ja wie?
Gibt es Tutorials oder andere Quellen (gerne auch in Englisch) die das Beschreiben?

:rtfm:Java TM Logging Overview

Ich schlage auch vor, die Datei logging.properties in Deinem JDK anzuschauen. Zusammen mit der Overview sollte dann vieles klarer sein.
 

jueki

Mitglied
Mit dieser Logging-Klasse habe ich keine erfahrung, aber ich habe das Problem über eine eigene Klasse mit einer statischen Funktion gelöst:
Java:
public class myGlobals
{

	/**
	 * Funktion schreibt eine Reportmeldung in eine festgelegte Textdatei
	 * und hängt einen Zeilenumbruch an.
	 * @param message [String] Abzuspeichernde Reportmeldung
	 */
	public static void reportln(String message)
	{
		try
		{
			FileWriter f = new FileWriter("../../report.txt", true); // Datei zum Anhängen öffnen
			message += "\n";
			f.write(message);
			f.close();
		}
		catch (Exception ex)
		{
			String error = "cant write Reportmessage '"
						 + message
						 + "'";
			System.out.println(error);
		}
	}
// ....
}

In irgendeiner anderen Klasse rufe ich die Funktion dann so auf:
Java:
myGlobals.reportln("blablabla");
Daneben habe ich mir noch eine statische Funktion geschrieben, die die Datei löscht, neu anlegt und das aktuelle Datum und einigen anderen Unsinn an den Anfang schreibt. Diese Funktion wird beim Programmstart aufgerufen. Klappt eigentlich ganz prima, könnte aber bei Threads probleme machen.

jueki
 

turtle

Top Contributor
Ich beschreibe mal kurz meine Nutzung von java.util.logging.

In einer Klasse A
Java:
public class A {
	private static final Logger logger = Logger.getLogger(A.class.getName()); 

	public static void main(String[] args) {
		logger.info("A gestartet");
		new B();
		logger.info("A beendet");
	}
}
In einer anderen Klasse B
Java:
public class B {
	private static final Logger logger = Logger.getLogger(B.class.getName()); 

	public B() {
		logger.info("B konstruiert");
	}
}
Das Logging-Verhalten wird über die Datei logging.properties gesteuert, die angibt, wohin und wie geloggt werden soll. Nehmen wie folgende Beispiel-Datei
Java:
.level = INFO
handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler
java.util.logging.FileHandler.pattern=logs/turtle.log
java.util.logging.FileHandler.formatter=java.util.logging.SimpleFormatter
Dieses gibt an, dass wir auf die Console und in die Datei logs/turtle.log loggen wollen. Und zwar alle Ausgaben ab Info-Level.
Startet man die Applikation mit java -Djava.util.logging.config.file=./logging.properties A werden folgende Ausgaben auf die Console und in die Datei gelogged:
Java:
25.07.2011 09:02:00 A main
INFO: A gestartet
25.07.2011 09:02:00 B <init>
INFO: B konstruiert
25.07.2011 09:02:00 A main
INFO: A beendet
 

FArt

Top Contributor
Der eine oder andere mag das Konzept einer Logging API noch nicht ganz verstanden haben.

Die Logger(-Instanzen) sind von den Appendern (z.B. für Logfiles) komplett getrennt. Über Konfiguration wird festgelegt, welche Logger auf welchen Appendern loggen. Dort kann man dann auch Loglevel, Filter, Format usw. konfigurieren.

Ich empfehle log4j, m.E. die mächtigste Logging API.
 

backarc

Mitglied
Moin!

Danke für eure Antworten!
Wenn ich das richtig verstehe war mein Ansatz also grundfalsch - und FArt hat recht mit der Aussage das ich das nicht verstanden habe.
In den Tutorials die ich gefunden habe wird das allerdings auch immer nur für eine Klasse - wie im Beispiel an der Java-Doku die turtle gepostet hat (Ich habe mich an der 1.6er Doku versucht, kaum ein Unterschied).

Für mich bedeutet das also:
Jede Klasse hat eine eigene Instanz von Logger, die ich in der Klasse nicht näher konfiguriere.
Im Projekt-Root gibt es eine Datei "logging.properties" in der ich Klassenübergreifend meinen File-Handler und den Log-Level einstelle.
Richtig?
 

turtle

Top Contributor
Im Projekt-Root gibt es eine Datei "logging.properties" in der ich Klassenübergreifend meinen File-Handler und den Log-Level einstelle.

Wenn Du java.util.logging einsetzen möchtest, ja.

Aber wie bereits angemerkt, setze ich und viele andere lieber log4j ein. Nutzung im Prinzip gleich. Bei log4j kann zum Beispiel das Log-Format einfacher eingestellt werden und die Konfigurationsdatei heisst log4j.properties.
 

backarc

Mitglied
Danke nochmal für eure Hilfe und die Bestätigung meines Verständnisses :)
Wie schon gesagt, log4J fällt aus meinem Konzept heraus ;) - ich möchte gerne Java "pur" nutzen solange möglich. Und wenn es noch so weh tut.

Danke & Gruss

backarc
 

backarc

Mitglied
Nun kann ich auch eine mögliche Lösung präsentieren - wenn es auch ein wenig gedauert hat.
Und falls es jemanden interessiert der eventuell dieselbe Lösung sucht - heir eine Möglichkeit.
Mit Sicherheit kann man noch am Code arbeiten.

Was ich interessant fand, ist das ich nachdem ich den Tipp mit den logging.properties aus den vorangegangenen Einträgen hatte, einige Artikel gefunden habe die das auch erklärt haben.
Warum ich das vorher nicht gefunden habe kann wahrscheinlich nur google beantworten.
Ich habe also nach
Java Standard: Logging API von Java ? Wikibooks, Sammlung freier Lehr-, Sach- und Fachbücher
und
Java Practices -> Logging messages
das folgende gebastelt:

Java:
#this file: see [url=http://de.wikibooks.org/wiki/Java_Standard:_Logging_API_von_Java]Java Standard: Logging API von Java ? Wikibooks, Sammlung freier Lehr-, Sach- und Fachbücher[/url]
# and [url]http://www.java-forum.org/allgemeine-java-themen/122068-java-util-logging-logger-mehre-klassen-logfile-schreiben-lassen.html#post788460[/url]
# Use -Djava.util.logging.config.file=logging.properties

# Der ConsoleHandler gibt die Nachrichten auf std.err aus
#handlers= java.util.logging.ConsoleHandler

# Alternativ können weitere Handler hinzugenommen werden. Hier z.B. der Filehandler
#handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler
handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler

# Festlegen des Standard Loglevels
.level= FINEST

# Die Nachrichten in eine Datei im Benutzerverzeichnis schreiben
java.util.logging.FileHandler.pattern = ttr_backend.log
java.util.logging.FileHandler.limit = 50000
java.util.logging.FileHandler.count = 1
# Style of output (Simple or XML):
java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter
#java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter

# Zusätzlich zu den normalen Logleveln kann fuer jeden Handler noch ein eigener Filter
# vergeben werden. Das ist nuetzlich wenn beispielsweise alle Nachrichten auf der Konsole ausgeben werden sollen
# aber nur ab INFO in das Logfile geschrieben werden soll.
#java.util.logging.ConsoleHandler.level = ALL
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter


############################################################
# Extraeinstellungen fuer einzelne Logger
############################################################

# Fuer einzelne Logger kann ein eigenes Loglevel festgelegt werden.
trainingstagebuchreader.gui.level = SEVERE
trainingstagebuchreader.gui.ttrGui.level = SEVERE
java.awt.level = SEVERE
sun.level = SEVERE

Und der Aufruf im Programm:
  1. Import:
    Java:
    import java.util.logging.Level;
    import java.util.logging.Logger;
  2. Eine Variable anlegen
    Java:
    private static final Logger logger = Logger.getLogger("Main");
  3. Und hier einen Log-Eintrag erzeugen (im Beispiel ein catch-block)
    Java:
    } catch (TTReaderException ex) {
                logger.log(Level.SEVERE, null, ex);
                System.out.println("Exception when reading login data from " + settingsfile + ex);
            }

Ich hoffe das das irgendwem weiterhilft.
Ich bedanke mich bei allen Helfern!
 

freez

Top Contributor
ich möchte gerne Java "pur" nutzen solange möglich

kleiner Gag: zieh dir die Sourcen zu log4j in dein Proejkt, dann hast du auch "Java pur" :) Nein, ernst beiseite:
Das heist
1. du brauchst Performance, die log4j nicht bieten kann? Oder
2. du willst es selber machen, um es einfach zu verstehen? Oder
3. das Jar ist einfach zu groß für dein Projekt. Oder
4. ich weiß keinen weiteren Grund, weshalb man auf diese einfache Art der Nutzung von Logging verzichten sollte.


Was ist deine Wahl?
 
Zuletzt bearbeitet:

backarc

Mitglied
Es geht mir um Punkt 2 (verstehen) und darum ein schlankes Programm zu basteln was überall funktioniert wo Java installiert ist.
Also idealerweise nur das was Java selbst mitliefert.

Das mag blöd sein.
Aber macht eigentlich Spaß :)
 

freez

Top Contributor
Es geht mir um Punkt 2 (verstehen) und darum ein schlankes Programm zu basteln was überall funktioniert wo Java installiert ist.

Das ist auch vollkommen ok. Jeder hier hat bestimmt schon mal Code geschrieben, obwohl eine freie Lib es auch kann ... Dabei ist auch schon mal was Besseres / Schnelleres / Anderes raus gekommen, und hatte sogar Erfolg. Also ruhig weiter so!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H java.util.logging Formatter Optionen setzen Allgemeine Java-Themen 2
S Tomcat java.util.logging - keine Logs Allgemeine Java-Themen 12
M Rat gesucht: Logging (log4J oder java.util.logging oder .) Allgemeine Java-Themen 5
M Verständnisfrage java.util.TimerTask Allgemeine Java-Themen 2
M java.util.prefs.Preferences "not visible" Allgemeine Java-Themen 7
J Compilerfehler bis in java.util.regex.Pattern... Allgemeine Java-Themen 2
P Input/Output java.util.Scanner in einer Schleife und Exception-Behandlung: Einlesen einer Zahl Allgemeine Java-Themen 4
D java.util.ConcurrentModificationException tritt auf Allgemeine Java-Themen 12
K Collections java.util.ConcurrentModificationException Allgemeine Java-Themen 3
H java.util.Timer und Funktion mit SQL Exception Allgemeine Java-Themen 5
S java.util.ConcurrentModificationException - aber nur ein Thread Allgemeine Java-Themen 3
N java.util.Date - Zeit auf 00:00 setzen Allgemeine Java-Themen 3
D java.util.ConcurrentModificationException - per Copy vermeiden Allgemeine Java-Themen 11
H java.util.random magischer Startwert? Allgemeine Java-Themen 2
D java.util.ConcurrentModificationException bei ArrayList Allgemeine Java-Themen 2
reibi Separator in java.util.Properties-Files Allgemeine Java-Themen 3
E Seltsamer aufruf von java.util.Date.toString() Allgemeine Java-Themen 3
D java.util.InputMismatchException im Scanner -wieso? Allgemeine Java-Themen 5
isowiz java.util.List: Sortierung nicht nach bestimmten Attribut? Allgemeine Java-Themen 4
R java.util.ConcurrentModificationException vermeiden? Allgemeine Java-Themen 8
2 In Jar schreiben? (java.util.jar) Allgemeine Java-Themen 9
V java.util.concurrent.RejectedExecutionException ? Allgemeine Java-Themen 1
J java.util.ConcurrentModificationException bei HashMap? Allgemeine Java-Themen 2
D Problem mit java.util.scanner: Falsche Ergebnisse Allgemeine Java-Themen 4
B java.util.zip Allgemeine Java-Themen 5
M Schnittstelle java.util.Set Allgemeine Java-Themen 9
G java.util.List klonen Allgemeine Java-Themen 17
A java.util.Regex :-( Allgemeine Java-Themen 5
P java.util.ConcurrentModificationException Allgemeine Java-Themen 9
P java.util.List - Typ überschreiben Allgemeine Java-Themen 9
H java.util.Vector langsam ? Allgemeine Java-Themen 5
N Java API java.util.vector Allgemeine Java-Themen 3
L properties auslesen funktioniert nicht(java.util.Properties) Allgemeine Java-Themen 3
L Frage zu java.util.regex und Einlesen einer Datei Allgemeine Java-Themen 2
T java.util.zip subfolders Allgemeine Java-Themen 2
K Wie gut sind java.util - ADTs ? Allgemeine Java-Themen 2
S java.util.Formatter Allgemeine Java-Themen 4
bernd java.util.Scanner erst ab Java 1.5? Allgemeine Java-Themen 4
I java.util.Date - die 1970-Untergrenze Allgemeine Java-Themen 3
A Split() - Methode und java.util.regex.* Allgemeine Java-Themen 2
V java.util.* vs java.sql.* Allgemeine Java-Themen 2
H java.util.Logger Allgemeine Java-Themen 5
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 0
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2

Ähnliche Java Themen

Neue Themen


Oben