Namensgebung der Dateien von FileHandler

G

Gast2

Gast
Hallo folgendes Problem:

Ich habe in meiner Software ein Loggingsystem, welches unter anderem den FileHandler verwendet. Dieser ist so konfiguriert, dass er rotierend 10 Logfiles ins APPDATA des Systems schreibt:

Java:
logger = Logger.getLogger(getClass().getName());
        try {
            logfileHandler = new FileHandler(logfilePath + LOGFILE, MAX_LOGFILE_SIZE, 10);
            final SimpleFormatter formatter = new SimpleFormatter();
            logfileHandler.setFormatter(formatter);
            logger.addHandler(logfileHandler);
            logger.setLevel(Level.ALL);
            logger.log(Level.INFO, "logfile created " + TimeString.get());
        } catch (final Exception ex) {
            logger.log(Level.SEVERE, "Cannot create file stream for logging!", ex);
        }

Bei jedem Startup werden aus dem Verzeichnnis alle ungültigen Dateien gelöscht:

Java:
        final File f = new File(logfilePath);
        final File[] fileArray = f.listFiles();
        for (final File file : fileArray) {
            if (!file.getName().startsWith(LOGFILE)) {
                //Files ist eine Utilitiy KLasse von unserer Firma, welche rekursives löschen unterstützt
                Files.delete(file);
            }
        }

Mein Problem ist nun folgendes:
Immer wenn eine zweite (oder xte) Instanz der Applikation erstellt wird, erstell der FileHandler nicht die Logfile mit nächst höheren Nummer sondern eine File:
Code:
LOGFILE_NAME.log.1.0

anstatt:
Code:
LOGFILE_NAME.log.2

Der Grund ist mir auch klar, da die *.log.1 ja noch von der vorgehenden Instanz geöffnet ist. Diese files werden aber natürlich nicht gecleaned, da sie valid sind. Sollen ja auch da bleiben für den Fall das man sie braucht.
Allerdings werden diese nunmal nicht zyklisch überschrieben, da sie ja nur entstehen, wenn mehrere instanzen gleichzeitig aktiv sind. (Was auch so sein soll/kann!).

Kann man das irgendwie unterbinden oder anders konfigurieren?
 

Andi_CH

Top Contributor
Für jede Instanz der Applikation ein anderes Directory oder mindestens einen anderen Filnamen.

Eine andere Möglichkeit ist es einen einzigen unabhängigen Logger zu starten und alles applikationsinstanzen kommunizieren mit dem
 
G

Gast2

Gast
Für jede Instanz der Applikation ein anderes Directory oder mindestens einen anderen Filnamen.
Dann müsste ich selber eine Instanzverwaltung machen, was ich eben verhindern wollte, da ich es nur hierfür benötigen würde.

Eine andere Möglichkeit ist es einen einzigen unabhängigen Logger zu starten und alles applikationsinstanzen kommunizieren mit dem
Zu aufwendig.

Notfalls lebe ich damit so wie es ist. Falls aber doch jemand nen Trick kennt, wie man das genannte Verhalten umgehen kann immer ehr damit!
 

Andi_CH

Top Contributor
Dann müsste ich selber eine Instanzverwaltung machen, was ich eben verhindern wollte, da ich es nur hierfür benötigen würde.

Zu aufwendig.

Notfalls lebe ich damit so wie es ist. Falls aber doch jemand nen Trick kennt, wie man das genannte Verhalten umgehen kann immer ehr damit!
Unterschiedliche Dateinamen sind sicher nicht aufwendig - da könnte die pid verwendet werden oder jede Instanz liest beim start aus einem gemeinsamen File wieviele andere schon laufen und schreibt selbst etwas hinein.

Ich vermute du wirst nicht mit deiner Lösung leben können - du stellst in einem logfile in Problem fest, hast aber keine Ahnung welche Instanz das war - na ja ....

Das ist halt der ganz grosse Nachteil von Frameworks - mein in 2 Stunden gebastelter Logger kann das, braucht keine XML oder was auch immer für Konfigurationen und tut trotzdem ;-) Einarbeit in ein Framework, dass dann noch massiven overhead mit sich bringt, den ich nicht brauche, ist ein Vielfaches davon.
 
G

Gast2

Gast
Ich benutze den Java Logger kein Framework... Das sind 3 Zeilen Code die man auch noch von Sun bekommt. Wo ist denn das Overhead?!

Und es wäre deutlich mehr Arbeit das mit der Instanzunterscheidung zu machen. Im übrigen steht in der Logfile welcher Fehler wo im Code auftrat. Da ist es sch*** egal in welcher Instanz das passierte.

Mein Problem besteht lediglich im aufräumen des Logfile Verzeichnisses, da nicht deterministische Dateinamen entstehen können... wie eben beschrieben...

Das ist aber durchaus vertretbar, da im Normalfall eh nur eine Instanz ausgeführt werden kann.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
G Dateien lesen Allgemeine Java-Themen 3
OnDemand Unterschiedliche jar Dateien zusammen führen Allgemeine Java-Themen 8
A Sicheres Löschen von Dateien Allgemeine Java-Themen 7
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
Master3000 Dateien zwischen verschiedenen Netzwerken senden Allgemeine Java-Themen 17
L Jar Dateien in Classpath laden ab JDK 9+ Allgemeine Java-Themen 11
d.lumpi JDA eclipse dateien versenden Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
O Wie kann ich in Apache POI (Excel Dateien schreiben) Datumszellen in Excel erzeugen Allgemeine Java-Themen 6
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
L Dateien richtig auslesen Allgemeine Java-Themen 6
L Eclipse Runnable Jar mit Dateien Allgemeine Java-Themen 8
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
MiMa Logging mit log4j2 in verschiedene Dateien? Allgemeine Java-Themen 22
I Klassen aus Jar-Dateien aus anderem Ordner laden Allgemeine Java-Themen 3
O jar und EXE Dateien, Pfade zur Laufzeit Allgemeine Java-Themen 1
W Dateien werden nicht gelöscht - warum? Allgemeine Java-Themen 12
B Dateien / Bilder von "webapp" Ordner bekommen? Allgemeine Java-Themen 1
P Erste Schritte Dateien löschen Allgemeine Java-Themen 4
H Erste Schritte Ausführbare Dateien lassen sich nicht starten Allgemeine Java-Themen 5
I Java als exe veröffentlichen inkl. kompletter Dateien Allgemeine Java-Themen 4
M Drucken von Dateien Allgemeine Java-Themen 10
J jar Dateien unter Windows 7 mit spezifischer jdk öffnen Allgemeine Java-Themen 2
I Laden von Informationen aus Dateien: Austauschbarkeit: 2 Dateien sinnvoll? Allgemeine Java-Themen 2
N Temporäre Dateien Allgemeine Java-Themen 3
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
M Dateien schneller kopieren Allgemeine Java-Themen 1
M Dateien nach kopieren vergleichen Allgemeine Java-Themen 9
Arif Input/Output Dateien im Jar-Programm speichern Allgemeine Java-Themen 12
D Collections.sort funktioniert nicht in exportierten .class Dateien Allgemeine Java-Themen 10
K Große JSON-Dateien schnell und effizient verarbeiten Allgemeine Java-Themen 16
J Programm zum Download von CSV-Dateien Allgemeine Java-Themen 4
V Eclipse .class Dateien Allgemeine Java-Themen 9
B Download von dateien Allgemeine Java-Themen 2
K Nicht alle class-Dateien im JRE? Allgemeine Java-Themen 2
MiMa Log4j in Dateien mit eigenem Namen schreiben Allgemeine Java-Themen 3
D Kopieren von Dateien aus einem Ordner in einen anderen Allgemeine Java-Themen 6
C Dateien in Jar aufrufen Allgemeine Java-Themen 14
X NetBeans Bilder und andere Dateien ins .jar schreiben und wieder aus .jar lesen Allgemeine Java-Themen 6
JavaWolf165 Externe .jar-Dateien in .jar-Datei intigrieren Allgemeine Java-Themen 0
X Dateien für Benutzer Sperren Allgemeine Java-Themen 4
D Dateien aus den Internet herunterladen Allgemeine Java-Themen 6
L Methoden Dateien älter als 30 Tage? Allgemeine Java-Themen 11
J .exe Dateien werden nicht gestartet obwohl Pfad richtig Allgemeine Java-Themen 6
RalleYTN Classpath Native Dateien(DLL, SO, JNILIB) Allgemeine Java-Themen 2
J Java .jar Dateien zusammenführen Allgemeine Java-Themen 1
L Best Practice Log Dateien analysieren und eventuell passende Daten am Chart darstellen Allgemeine Java-Themen 1
F Platzsparende Alternative zu .txt-Dateien Allgemeine Java-Themen 12
X Dateien von der Jar zum Ordner kopieren. Allgemeine Java-Themen 4
Ananaskirsche Input/Output Dateien im Ordner Allgemeine Java-Themen 8
A Input/Output Liste der Dateien in einem Ordner in einer Jar Datei erhalten Allgemeine Java-Themen 11
X Herunterladen von Dateien aus dem Internet Allgemeine Java-Themen 2
V Input/Output Sound Dateien aus Jar laden Allgemeine Java-Themen 18
M Dateien aus einem Verzeichnis auf einem Server auflisten Allgemeine Java-Themen 5
H PDFBox akzeptiert Dateien nicht Allgemeine Java-Themen 1
B Java - einlesen von Dateien und herausschneiden von XML Dokumenten Allgemeine Java-Themen 5
A Input/Output Spätes Schreiben von Dateien der JVM Allgemeine Java-Themen 3
M Zwei unterschiedliche JAR Dateien mit ANT erstellen Allgemeine Java-Themen 8
Thallius Dateien Zippen und wieder heraus lesen? Allgemeine Java-Themen 4
T Dateien zur Laufzeit in Java-Programm packen? Allgemeine Java-Themen 3
Maxim6394 Jar Dateien starten nicht Allgemeine Java-Themen 7
U Eclipse Java Programm beschädigt .tar.gz dateien beim Entpacken Allgemeine Java-Themen 7
GUI-Programmer Mp3 Dateien bearbeiten und speichern Allgemeine Java-Themen 3
S Exklusive Sperre auf Dateien: FileChannel, FileLock Allgemeine Java-Themen 0
Bluedaishi Dateien löschen die älter als das aktuelle Datum sind Allgemeine Java-Themen 9
OnDemand Dateien einlesen und vergleichen Allgemeine Java-Themen 1
T Ordner samt Dateien kopieren Allgemeine Java-Themen 11
R Importieren von Txt-Dateien in AbstractTableModel Allgemeine Java-Themen 0
C Dateien komprimieren und verschlüsseln Allgemeine Java-Themen 3
F Eclipse Eclipse kompiliert nicht mehr die aktuellen Dateien Allgemeine Java-Themen 2
R Java Dateien "verschlüsseln" Allgemeine Java-Themen 2
L Passwortgeschützte Dateien Allgemeine Java-Themen 6
A Datentypen Dateien umbenennen mit Dateiendungen - Dateiendungen ausgeben Allgemeine Java-Themen 2
L Reparieren beschädigter PDF Dateien Allgemeine Java-Themen 3
F Dateien ins Array lagern und Optionen zur Auswahl, Allgemeine Java-Themen 5
J XML Dateien vergleichen Allgemeine Java-Themen 9
B Umbenennen von Dateien Allgemeine Java-Themen 2
B Erste Schritte Plugin erkennen und Class Dateien anzeigen lassen Allgemeine Java-Themen 3
W Best Practice Dateien parsen Allgemeine Java-Themen 3
B Dateien verschwinden aus bin Ordner?! Allgemeine Java-Themen 5
B Dateien prüfen auf Gleichheit Allgemeine Java-Themen 5
M Java Dateien verschieben Allgemeine Java-Themen 2
R Wav-Dateien wiederholt abspielen Allgemeine Java-Themen 2
L Methoden Verarbeitung von Größen Dateien Allgemeine Java-Themen 9
B Alt-Griechisch Zeichen in Dateien Allgemeine Java-Themen 2
M JAR Dateien nur mit Compiler Level 1.6 ausführbar Allgemeine Java-Themen 8
E Zugriff auf Dateien im Filesystem überwachen Allgemeine Java-Themen 5
G .jar Dateien lassen sich nicht mehr öffnen Allgemeine Java-Themen 2
M Datentypen Jar-Dateien öffnen nicht mit Java Allgemeine Java-Themen 4
C Mit Java PDF Dateien bearbeiten. Allgemeine Java-Themen 2
B Input/Output .java-Dateien auslesen Allgemeine Java-Themen 17
B Methoden Alle Methoden und Variablen aus Java-Dateien auslesen. Allgemeine Java-Themen 7
E Vorschläge, effizientes Hashing von Dateien für vergleich Allgemeine Java-Themen 7
W Vergleich eines Datenträgers auf neue Dateien Allgemeine Java-Themen 14
C Java-Dateien in einheitlichen Zeichensatz umwandeln Allgemeine Java-Themen 10
E Dateien aus / im JAR Allgemeine Java-Themen 2
K LibreOffice Tabelle Dateien im Format .ods bearbeiten Allgemeine Java-Themen 2
L Input/Output Dateien erstellen, wenn ein JAR ausgeführt wird Allgemeine Java-Themen 13
L Generieren Zufallsdaten aus CSV dateien Allgemeine Java-Themen 11

Ähnliche Java Themen

Neue Themen


Oben