Programm startet sich selbst neu, alte Logfiles bleiben gesperrt

Also ich hab ein etwas aussergewöhnliches Problem. Ich habe einen Java Prozess der sich nach einer gewissen Anzahl Durchgänge neu starten soll und seine Consolenausgaben in .txt Datein umleitet. Bei jedem Start werden zwei neue Files (Für Output und Error Stream) angelegt und der alte Prozess beendet sich mit System.exit(0) selbst. Dennoch bleiben alle Logfiles gesperrt solange immer wieder ein Nachfolgeprozess läuft. Dieses Problem besteht nur unter Windows unter Unix funktioniert das Verfahren.

Um das ganze etwas zu Veranschaulichen:

Nach X-Durchgängen starte ich mein Programm auf diese weise neu:
Java:
Date date = new Date(System.currentTimeMillis());
String LOGFILEPFAD = "C:\\Logfiles\\";

Runtime.getRuntime().exec("cmd /c java -jar C:\\meinProgramm.jar -Xmx1024M 1>" + LOGFILEPFAD + new SimpleDateFormat("yyyy.dd.MM-HH.mm.ss").format(date) + "log.txt" + " 2>" + LOGFILEPFAD + new SimpleDateFormat("yyyy.dd.MM-HH.mm.ss").format(date) + "err.txt");

System.exit(0)

Nun legt der neue Prozess zwei neue Files an und schreibt seine Consolenausgaben in diese. Die alten Files der vorherigen Prozesse bleiben aber gesperrt und können nicht gelöscht oder verschoben werden. Wie gesagt das Problem besteht nur unter Windows.

MfG MasterChristian
 

arilou

Bekanntes Mitglied
Weil du es eigentlich falsch anstellst. Der "neue Prozess" darf nicht Kindprozess des noch laufenden sein.
Denn die JVM muss
  • entweder den Elternprozess so lange stoppen (und nicht beenden), wie noch ein Kindprozess läuft (so scheint es die Win-JVM korrekt zu machen),
  • oder den Kindprozess mitsamt dem Elternprozess killen.
Bei Linux scheinst du Glück zu haben, dass der Kindprozess noch einen Moment weiterlaufen darf - oder hast ihn (ausversehen) so gestartet, dass er nicht als Kindprozess läuft.

Ich denke mal, dass du auch für alle Files, Reader/Writer usw. immer schön .close() aufrufst, damit sie auch geschlossen sein können, wenn der Elternprozess noch (halb) lebt...
 
Zuletzt bearbeitet:
Hab nun eine Lösung gefunden:

Ich leite die Streams am anfang der Main in die Files um:
Java:
	private void initLogfiles() {
		Date date = new Date(System.currentTimeMillis());
		String logString = LOGFILEPFAD + new SimpleDateFormat("yyyy.dd.MM-HH.mm.ss").format(date) + "log.txt";
		String errString = LOGFILEPFAD + new SimpleDateFormat("yyyy.dd.MM-HH.mm.ss").format(date) + "err.txt";
		
		try {
			PrintStream out = new PrintStream(new FileOutputStream(logString));
			System.setOut(out);
			PrintStream err = new PrintStream(new FileOutputStream(errString));
			System.setErr(err);
		} 
		catch (FileNotFoundException e) {
			e.printStackTrace();
		}
	}

Dann starte ich das Programm auf diese weise neu:
Java:
Runtime.getRuntime().exec("cmd /c java -jar C:\\meinProgramm.jar -Xmx1024M");
System.out.close();
System.err.close();
System.exit(0);

Ob das System.out.close() überhaubt nötig ist hab ich jetzt noch nicht getestet.

MfG MasterChristian
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Programm startet nicht, nur per cmd Allgemeine Java-Themen 5
K Programm startet nur auf eigenem Rechner??? Allgemeine Java-Themen 6
J Programm von CD startet nicht (autorun/autostart/jre Allgemeine Java-Themen 38
W Programm startet nur mit der JDK Allgemeine Java-Themen 10
S Programm über Konsole startet nicht Allgemeine Java-Themen 2
Jose05 Umgang mit Exceptions in einen Programm Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
R Programm führt Methoden gleichzeitig aus Allgemeine Java-Themen 2
T Der Aufruf von CMD-Programm Allgemeine Java-Themen 30
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
Mike80 Processing Programm fiert ohne Arduino ein Allgemeine Java-Themen 2
B Mysteriöse Ergebnisse beim Baccarat Programm? Allgemeine Java-Themen 13
districon Programm zum Durchsuchen von (Ebay-)Artikeln Allgemeine Java-Themen 1
T Addons im eigenen Programm Allgemeine Java-Themen 1
Calli11 Was muss ich hier in die Main schreiben, damit das Programm ausgeführt wird? Allgemeine Java-Themen 4
S .exe Datei/Programm auslesen? Allgemeine Java-Themen 2
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
Alex_99 Programm stürzt beim Aufruf der Funktion ab? Text ausgeben Allgemeine Java-Themen 45
B Java Programm auf virutellem Desktop laufen lassen? Allgemeine Java-Themen 1
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
Tiago1234 Warum hängt sich mein Programm auf? Allgemeine Java-Themen 22
D Programm designen Allgemeine Java-Themen 1
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
O 2D-Grafik BioFarben-Programm soll auf Vollbild schalten Allgemeine Java-Themen 1
S Nachrichten Filter Programm Allgemeine Java-Themen 14
S Programm schreiben, das mir aufgrund von Schlagwörtern, die ich im Internet suche, relevante Themen sofort anzeigt. Allgemeine Java-Themen 1
T Hilfe bei Programm. IDE: Eclipse mit EV3-Plugin, lejos Allgemeine Java-Themen 8
Lukas2904 Swing Anzeigen lassen das das Programm geschlossen wurde Allgemeine Java-Themen 3
TechnikTVcode Mail Programm Allgemeine Java-Themen 2
S Programm entwickeln, welches ein Dreieckspuzzle lösen kann Allgemeine Java-Themen 5
R Lesen von Interfaces (Programm Vervollständigen) Allgemeine Java-Themen 10
Dann07 Java-Programm findet DLLs nicht! Allgemeine Java-Themen 20
OSchriever Linux-Programm öffnen Allgemeine Java-Themen 6
P USER Management in SQL übergreifend auf JAVA Programm Allgemeine Java-Themen 41
L Eclipse Konsole im exportierten Programm Allgemeine Java-Themen 2
OSchriever Programm über Linux-Kommandozeile ausführen Allgemeine Java-Themen 20
D Verkauf von einem Programm welches ich in Java geschrieben habe Allgemeine Java-Themen 4
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P Erstelltes Programm ist doppelt so groß Allgemeine Java-Themen 11
N Programm nach Abschluss neustarten lassen Allgemeine Java-Themen 6
S Einfaches Programm programmieren Allgemeine Java-Themen 5
M kleines KI Programm Idee Allgemeine Java-Themen 7
D Boolean von ein anderem Java Programm während der Laufzeit ändern Allgemeine Java-Themen 23
L Excel Datei löscht sich selbst im Programm - Java Allgemeine Java-Themen 3
I File ausführen und mein Programm bearbeiten lassen Allgemeine Java-Themen 11
ralfb1105 Starten Java App(s) (.jar) aus einem Java Programm Allgemeine Java-Themen 18
temi Java Programm aus einer DB laden und starten Allgemeine Java-Themen 2
J Programm zum Suchen eines Wortes im Dateisystem Allgemeine Java-Themen 4
E Java Programm mit Clients erweitern - Möglichkeiten? Allgemeine Java-Themen 2
Joker4632 Methoden Befehl an bereits extern geöffnete Programm-spezifische Konsole senden Allgemeine Java-Themen 1
M Dieses Programm schneller machen? Allgemeine Java-Themen 2
R Programm zur Rekursion Allgemeine Java-Themen 5
N Quicksort Programm hängt sich auf Allgemeine Java-Themen 6
S Compiler-Fehler Programm verhält sich in Eclipse anders Allgemeine Java-Themen 1
B Input/Output Programm zum Auslesen/Beschreiben von Textdateien, wie Geschwindigkeit erhöhen? Allgemeine Java-Themen 18
dereki2000 Programm veröffentlichen Allgemeine Java-Themen 14
mrbig2017 Threads Chat Programm mit Threads? Allgemeine Java-Themen 2
M Suche aktuelle Apache Poi Bibliothek zum Einbinden in mein Programm Allgemeine Java-Themen 2
J Java "Bank Programm" Brauche eure Hilfe Allgemeine Java-Themen 3
S Java Programm (Spiel mit den Boxen) Allgemeine Java-Themen 1
kodela Programm hängt in der Ereigniswarteschlange Allgemeine Java-Themen 13
A Java Programm verbessern/vereinfachen Allgemeine Java-Themen 20
P Programm darf nicht mehrfach startbar sein Allgemeine Java-Themen 16
S Programm hängt sich manchmal (selten) auf Allgemeine Java-Themen 9
JavaNewbie2.0 Programm nicht im Taskmanager schliesen können Allgemeine Java-Themen 15
J XML Datei mit installiertem Programm öffnen Allgemeine Java-Themen 7
Arif Input/Output Dateien im Jar-Programm speichern Allgemeine Java-Themen 12
H Java FX 2 Fragen um Programm in mehrere sprachen zu übersetzen in Gluon Framwork Allgemeine Java-Themen 3
JavaNewbie2.0 Programm bleibt "stehen" Allgemeine Java-Themen 2
JavaNewbie2.0 Start eines Anderen Programm erkennen Allgemeine Java-Themen 6
E Mit Java ein Python Programm starten Allgemeine Java-Themen 20
Q-bert Daten von Java Programm speichern Allgemeine Java-Themen 4
Aruetiise Methoden .jar mit Programm öffnen Allgemeine Java-Themen 2
C anderes Programm schließen! Allgemeine Java-Themen 5
C Webseiten Programm problem Allgemeine Java-Themen 5
E Programm auf Installation prüfen Allgemeine Java-Themen 1
J Programm zum Download von CSV-Dateien Allgemeine Java-Themen 4
E Programm ohne Windowsrand(Vollbild) ? Allgemeine Java-Themen 5
G Programm, das nach abgearbeiteter main Methode weiterläuft Allgemeine Java-Themen 72
P Schnittstelle java Programm zu Webserver / Browser Allgemeine Java-Themen 2
J Schutz Programm Jar Exe Allgemeine Java-Themen 7
R javax.comm --> Programm funktioniert nach Export nicht mehr Allgemeine Java-Themen 0
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
U Input/Output Warum wirft mir das Programm diesen Fehler? Allgemeine Java-Themen 6
X jvm exception abfangen und an externes Programm schicken Allgemeine Java-Themen 4
B Programm updaten mit FXLauncher Allgemeine Java-Themen 1
D Nicht quelloffenes Programm Allgemeine Java-Themen 5
F Java-Programm lizensieren Allgemeine Java-Themen 21
I Programm im Hintergrund bei Windows zur Steuerung der Tastatur nutzen Allgemeine Java-Themen 2
X Aus Programm "Installationsprogramm" machen Allgemeine Java-Themen 6
T Java Programm in Internetseite? Allgemeine Java-Themen 4
T Java Programm frisst RAM Allgemeine Java-Themen 6
H Alter Java-Programm läuft nicht mehr. Laut strace fehlt libpthread.so.0 Allgemeine Java-Themen 3
H Runtime reagiert erst wenn Programm abbricht Allgemeine Java-Themen 1
E Exceptions abfangen und dann Programm stoppen - aber wie? Allgemeine Java-Themen 2
Neumi5694 Offenes Programm nutzen Allgemeine Java-Themen 4
L Java-Programm Zahlenkombinationen ausgeben Allgemeine Java-Themen 10
KaffeeFan Methoden Suche Methode um Programm kurz warten zu lassen Allgemeine Java-Themen 22

Ähnliche Java Themen

Neue Themen


Oben