AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?
Thema durchsuchen
Ansicht
Themen-Optionen

Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

Ein Thema von romber · begonnen am 16. Mai 2013 · letzter Beitrag vom 17. Mai 2013
Antwort Antwort
Seite 1 von 2  1 2      
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.166 Beiträge
 
Delphi 10 Seattle Professional
 
#1

Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 16. Mai 2013, 22:41
Delphi-Version: 5
Hallo!

Bei meinem Progamm handelt es sich um einen recht einfach aufgebauten TCP-Server, der permanent große Mengen an Daten (bis zu 200 Datenzätze pro Sekunde) von einem Webservice geliefert bekommt und diese Daten dann an die verbundene Clients weiter verteilt. Das Programm soll auf einem gemietetet Windows-Server im Dauerbetrieb laufen. Es gibt aber ein Problem. Tritt zwar sehr selten auf, aber trozdem ärgerlich. Und zwar stürzt das Programm plötzlich ab. Es erscheint die typiscge Windows-Meldung "Programm funktioniert nicht mehr, Windows kann online nach einer Lösung suchen".

Was ist das für ein Fehler?
Ist das ein AV oder was ist das?
Was ist die häufigste Ursache für ein solches Problem?

Im Debugmodus kann ich das Programm zwar starten, diese dauerhaft im Debugmodus laufen zu lassen ist leider nicht möglich. Sobald der Webservice-Client beginnt die Daten zu saugen friert im Debugmodus alles ein, so viele Datensätze sind es.

Wie kann ich die Stelle (Zeile oder wenigstens die Funktion) im Code finden, die das Problem verursacht?

Im Voraus vielen Dank!
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.664 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 16. Mai 2013, 23:14
Probiere mal einen Handler mit TApplicationEvents für OnException. Wenn du darin landest, kannst du mit JclDebug aus der JEDI Code Library auch einen Stacktrace erstellen.

Alternativ gibt es mit MadExcept und EurekaLog kommerzielle Alternativen, die dir zeigen wo die entsprechende Exception (die es sein wird und nicht abgefangen wird) auftritt.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#3

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 16. Mai 2013, 23:34
Das Einfrieren im Debug-Modus könnte aber auch schon ein guter Hinweis sein. Wenn ich nicht irre, gibt Windows eben diese Meldung aus, wenn ein Programm seine Message-Queue nicht mehr zeitnah verarbeitet - sprich: Es ist zu beschäftigt / überlastet. Einfach zu provozieren mittels einer Dauerschleife im Hauptthread ohne Application.ProcessMessages darin.

Ich würde daher fast darauf tippen, dass dein Programm die Hardware schlicht und einfach überfordert. Man könnte zwar daher gehen und die Verarbeitung der lange dauernden Dinge in einen anderen Thread werfen, damit der Hauptthread brav weiterhin seine Messages bedient, jedoch wird der Thread dann irgendwann seinen Jobs weit hinter her laufen und ggf. den Speicher mit seiner Job-Queue füllen.

Lösungsideen: Wenn der PC eine Multicore CPU hat, und die Verarbeitung parallelisierbar ist, wären mehrere Threads ein Weg. Allerdings auch nur, wenn die CPU-Zeit der Flaschenhals ist (eher selten der Fall). Herauszubekommen, indem du dir mal den Taskmanager beguckst während dein Programm läuft, in dem Register "Leistung". Wenn dort ein Kern voll ausgelastet ist, dann wäre das eine Option (wenn die Aufgabe eben parallelisierbar ist). Sonst nicht.
Eine andere Option wäre schlicht schnellere Hardware. Als erstes würde ich aber versuchen zu gucken, ob sich innerhalb der Verarbeitungsfunktionen nicht einige Geschwindigkeitsfallen befinden, oder gar schon das Kommunikationsprotokoll auf Performance optimieren.

Fazit: Diese Art von Fehler würde ich weniger in einer Exception suchen, als viel mehr ein Performanceproblem vermuten. Ob und wo da die geeigneten Stellschrauben sind dies zu eliminieren ist höllisch individuell.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.166 Beiträge
 
Delphi 10 Seattle Professional
 
#4

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 16. Mai 2013, 23:38
Vielen Dank für die schnelle Reaktion!

Probiere mal einen Handler mit TApplicationEvents für OnException. Wenn du darin landest, kannst du mit JclDebug aus der JEDI Code Library auch einen Stacktrace erstellen.
Habe das mit Stacktrace noch nie gemacht. Jedi (Jcl und Jvcl) sind bei mir installiert, finde JclDebug aber nicht. Wie genau soll ich vorgehen?

Alternativ gibt es mit MadExcept und EurekaLog kommerzielle Alternativen, die dir zeigen wo die entsprechende Exception (die es sein wird und nicht abgefangen wird) auftritt.
Zeigt mir z.B. EurekaLog genau die Stelle im Code, die das Problem verursacht oder bekomme ich wieder irgendwelche Adressen angezeigt? Wenn das so ist, dann kaufe ich gleich das Programm und spare die Zeit.
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.166 Beiträge
 
Delphi 10 Seattle Professional
 
#5

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 16. Mai 2013, 23:56
Das Einfrieren im Debug-Modus könnte aber auch schon ein guter Hinweis sein. Wenn ich nicht irre, gibt Windows eben diese Meldung aus, wenn ein Programm seine Message-Queue nicht mehr zeitnah verarbeitet - sprich: Es ist zu beschäftigt / überlastet. Einfach zu provozieren mittels einer Dauerschleife im Hauptthread ohne Application.ProcessMessages darin.

Ich würde daher fast darauf tippen, dass dein Programm die Hardware schlicht und einfach überfordert. Man könnte zwar daher gehen und die Verarbeitung der lange dauernden Dinge in einen anderen Thread werfen, damit der Hauptthread brav weiterhin seine Messages bedient, jedoch wird der Thread dann irgendwann seinen Jobs weit hinter her laufen und ggf. den Speicher mit seiner Job-Queue füllen.

Lösungsideen: Wenn der PC eine Multicore CPU hat, und die Verarbeitung parallelisierbar ist, wären mehrere Threads ein Weg. Allerdings auch nur, wenn die CPU-Zeit der Flaschenhals ist (eher selten der Fall). Herauszubekommen, indem du dir mal den Taskmanager beguckst während dein Programm läuft, in dem Register "Leistung". Wenn dort ein Kern voll ausgelastet ist, dann wäre das eine Option (wenn die Aufgabe eben parallelisierbar ist). Sonst nicht.
Eine andere Option wäre schlicht schnellere Hardware. Als erstes würde ich aber versuchen zu gucken, ob sich innerhalb der Verarbeitungsfunktionen nicht einige Geschwindigkeitsfallen befinden, oder gar schon das Kommunikationsprotokoll auf Performance optimieren.

Fazit: Diese Art von Fehler würde ich weniger in einer Exception suchen, als viel mehr ein Performanceproblem vermuten. Ob und wo da die geeigneten Stellschrauben sind dies zu eliminieren ist höllisch individuell.
Es ist ein Multicore CPU und natürlich wird nicht alles im Hauptthread erledigt. Genauer gesagt es wird praktisch nichts im Hauptthread erledigt. Jeder Datensatz wird von einem neuen Thread für die "Weiterverarbeitung" übernommen. Das verarbeitete Ergebnis landet dann in einem Container. Die Client-Threads (TIdTCPServer) beobachten den Container und greifen sich die neue Daten. Das ganze wird so geregelt, dass eine bestimmte max. Anzahl der Threads gleichzeitig ausgeführt werden.

Die CPU-Auslastung klettert kaum über 15%.
Miniaturansicht angehängter Grafiken
screenshot.jpg  
  Mit Zitat antworten Zitat
Benutzerbild von Dalai
Dalai

Registriert seit: 9. Apr 2006
1.682 Beiträge
 
Delphi 5 Professional
 
#6

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 17. Mai 2013, 00:21
@Medium: Vielleicht verstehe ich dich falsch, aber es geht nicht um die Meldung "Programm reagiert nicht mehr" bzw. "Keine Rückmeldung" sondern um ein Wegschmieren der Anwendung mit der Meldung "Programm funktioniert nicht mehr" der Fehlerberichterstattung bzw. Dr. Watson. Wenn ein Programm nicht mehr reagiert, läuft es trotzdem weiter (eben ohne ProcessMessages & Konsorten), aber wenn es nicht mehr funktioniert, wurde es (aufgrund einer nicht gefangenen Exception) geschlossen.

MfG Dalai
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.664 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 17. Mai 2013, 06:30
Zeigt mir z.B. EurekaLog genau die Stelle im Code, die das Problem verursacht oder bekomme ich wieder irgendwelche Adressen angezeigt? Wenn das so ist, dann kaufe ich gleich das Programm und spare die Zeit.
Wenn es eine Exception ist, wird die in der Regel von diesen Tools abgefangen (durch mit einkompilierten Code) und du bekommst den Stacktrace aller laufenden Threads, Memorydumps an den Exceptionstellen usw., auch per Mail senden kannst du aktivieren (wenn der Benutzer selbst dir den Bericht schicken können soll).

Auch ein hängendes Programm wird durch Eurekalog durch einen zusätzlichen Thread gut erkannt.

Alternative wäre .dbg Dateien aus den Debuginfos von Delphi zu generieren und diese mitzuliefern, dann bekommst du den Stacktrace auch direkt in den Dr. Watson Logs von Windows.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
hathor
(Gast)

n/a Beiträge
 
#8

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 17. Mai 2013, 08:42
Schon mal in die Log-Files geguckt?
Ereignisanzeige: eventvwr.msc
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.166 Beiträge
 
Delphi 10 Seattle Professional
 
#9

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 17. Mai 2013, 09:38
Schon mal in die Log-Files geguckt?
[/B]
Ja, die Meldung bringt mich aber nicht wirklich weiter.
Code:
Name der fehlerhaften Anwendung: verteiler.exe, Version: 3.0.0.307, Zeitstempel: 0x519431bf
Name des fehlerhaften Moduls: KERNELBASE.dll, Version: 6.1.7601.18015, Zeitstempel: 0x50b83c8a
Ausnahmecode: 0x0eedfade
Fehleroffset: 0x0000c41f
ID des fehlerhaften Prozesses: 0x53d8
Startzeit der fehlerhaften Anwendung: 0x01ce52269adfa062
Pfad der fehlerhaften Anwendung: D:\Projekte\DSA\Verteiler\verteiler.exe
Pfad des fehlerhaften Moduls: C:\Windows\syswow64\KERNELBASE.dll
Berichtskennung: 9b18c2c7-be1a-11e2-95cb-08606e44cb44
  Mit Zitat antworten Zitat
greenmile

Registriert seit: 17. Apr 2003
1.107 Beiträge
 
Delphi 10.3 Rio
 
#10

AW: Windows-Meldung "Programm funktioniert nicht mehr": Problem finden?

  Alt 17. Mai 2013, 09:53
Wenn Du im Haupthread auf Nachrichten wartest und das in einer Schleife, dann funktioniert das:

Zitat:
Das Einfrieren im Debug-Modus könnte aber auch schon ein guter Hinweis sein. Wenn ich nicht irre, gibt Windows eben diese Meldung aus, wenn ein Programm seine Message-Queue nicht mehr zeitnah verarbeitet - sprich: Es ist zu beschäftigt / überlastet. Einfach zu provozieren mittels einer Dauerschleife im Hauptthread ohne Application.ProcessMessages darin.
Code:
Inc(Counter)
If (Counter mod 5)=0 then Application.Processmessages;
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:29 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz