Java Logging API

Wang

Bekanntes Mitglied
Hallo,

es wäre sehr nett, wenn sich jemand das kleine Beispielprogramm auf den Seiten 9, 10, 11 unter dem Link http://berrendorf.inf.fh-bonn-rhein-sieg.de/lehre/ss03/vups1/Seminar/3_LoggingInJava.pdf ansehen könnte, denn ich habe dort ein paar Verständnisprobleme (für eine bessere Übersicht habe ich den Quellcode der drei Klassen hier nicht eingefügt, kann das aber gerne machen, wenn das für Euch besser sein sollte):

- In der Klasse LoggingA wurde der Log Level des Handlers nicht gesetzt. Gilt dann der Default global logging level aus der Datei
Code:
<java_home>/jre/lib/logging.properties
?
- In der Klasse LoggingB heißt es
Code:
static Handler handler;
. Ich verstehe nicht, warum das als Klassenvariable definiert wird (werden muss?)?
- Meint das
Code:
logger.setUseParentHandlers(false);
in der Klasse LoggingB einfach nur, dass für diese Klasse der FileHandler aus der Klasse LoggingA nicht verwendet wird?
- In der Klasse LoggingC wird weder ein FileHandler noch ein Log Level definiert. Gelten dann die Default-Werte aus
Code:
<java_home>/jre/lib/logging.properties
?
- Müsste
Code:
LoggingB log_b = new LoggingB();
in der Klasse LoggingC nicht dazu führen, dass "LoggingA erzeugt." auf der Konsole ausgegeben wird ???:L

Vielen Dank für Eure Mühe!

Gruß
Wang
 

JPT

Mitglied
Darf ich fragen, warum du das Dokument nachvollziehen willst?
Ich bin mir nicht sicher, ob es geeignet ist Logging zu lernen.

Normalerweise werden weder Log-Level noch Handlers (Logfiles) im Java-Source konfiguriert.
Dies sollte in separaten Konfig-Dateien geschehen, denn der Witz der Loglevel bzw des Logging-Frameworks an sich ist, dass du je nach Umgebung (Entwicklung, Testen, Produktion) unterschiedliche Konfigurationen hast, sodass in Produktion wesentlich weniger geloggt wird als in der Entwicklung.
 

JPT

Mitglied
Ach ja... statisch sind Logger (und in dem Fall Handler), weil man sie nur einmal erzeugt, und für jede Instanz der loggenden Klasse wiederverwendet.
kann man auch anders machen, wenn zb der Logger Informationen über die aktuelle Instanz der Klasse besitzen soll. Hängt auch davon ab, wie lange eine Instanz dieser Klasse lebt, oder wie viele davon erzeugt werden.
Für den Handler in diesem speziellen Fall kann ich nicht sagen, ob er statisch sein MUSS.
 

Wang

Bekanntes Mitglied
Moin,

Darf ich fragen, warum du das Dokument nachvollziehen willst?
Ich bin mir nicht sicher, ob es geeignet ist Logging zu lernen.

ich habe in Google etliche Seiten abgeklappert, um das Logging mit der Java Logging API zu lernen und dieses Dokument schien dafür ziemlich gut zu sein.

Falls jemand die Zeit/Motivation hat, wäre es sehr nett, wenn jemand noch auf meine Fragen im ersten Beitrag eingehen könnte, denn ich habe da nachwievor Probleme...

Vielen Dank!

Gruß
Wang
 
J

JohannisderKaeufer

Gast
- Müsste
Code:
LoggingB log_b = new LoggingB();
in der Klasse LoggingC nicht dazu führen, dass "LoggingA erzeugt." auf der Konsole ausgegeben wird ???:L

Das hat mir auch erst Rätsel aufgegeben.
Das Problem ist das der Handler ein bestimmtes Loglevel hat. Aber auch der Logger hat ein Loglevel.

Logger ist default Level.INFO
Der Handler wird explizit auf Finest gesetzt.

Wenn nun geloggt wird, bekommt der Logger das Level der Nachricht mit (CONFIG) und entscheidet, so genau will ich es überhaupt nicht wissen.

Der Handler bekommt die Nachricht also garnicht zu sehen.

Ein Beispiel wäre, wenn du sagst, das du alles auf der Konsole ausgeben möchtest, zusätzlich aber Warning in die Datei schreiben möchtest.
Dann setzt du
Logger => ALL
und fügst 2 Handler Hinzu
ConsoleHandler => FINEST
FILEHANDLER => WARNING

Wenn nun ein Nachricht mit CONFIG kommt. Sagt der Logger, das ist in ALL enthalten und reicht es an seine Handler weiter.
ConsoleHandler verarbeitet da CONFIG in FINEST enthalten ist.
FILEHANDLER läßt die Nachricht aussen vor, da er nur auf WARNING und SEVERE reagiert.

- Meint das logger.setUseParentHandlers(false); in der Klasse LoggingB einfach nur, dass für diese Klasse der FileHandler aus der Klasse LoggingA nicht verwendet wird?

Das bezieht sich auf Packages.

Der Logger bekommt einen Namen i.d.R
package.subpackage.Klasse

Nun kann man in Propertiesdateien konfigurieren, das es verschiedene Logger gibt
package => Logger1
package.subpackage => Logger2
package.subpackage.Klasse => Logger3

Wenn für Logger3.useParentHandler = true konfiguriert ist und logger3 loggt, so wird die Nachricht auch mit Logger2 verarbeitet.
Wenn Logger2 eine Nachricht verarbeitet und Logger2.useParentHandler = false ist, so bekommt Logger1 die Nachricht nicht zu sehen.
Ich hoffe das ist einigermaßen nachvollziehbar.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
U Java logging generiert unerwünschten files Java Basics - Anfänger-Themen 1
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben