Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Windows Dienst lässt sich nicht starten?! Hilfe! (https://www.delphipraxis.net/165591-windows-dienst-laesst-sich-nicht-starten-hilfe.html)

DelphiPeter 7. Jan 2012 13:45

Delphi-Version: 2007

Windows Dienst lässt sich nicht starten?! Hilfe!
 
Hallo Freunde!

Ich verzweifel gerade an meinem Windows Dienst. Wenn ich ihn installiere, bekomme ich einen "Fehler 2 - Die angegebene Datei konnte nicht gefunden werden".

Also habe ich alles durch debuggt. Ergebnis, auf alle Dateien auf die ich physikalisch zugreife, hat er auch zugriff, das erkenne ich unter anderm daran, das er in die Dateien reinschreibt.


Ich denke, ich habe einen Fehler in meinem Denkansatz, hier also das Prinzip des Dienstes:

onCreate:
- Lesen eines INI Eintrages zum detzen eines Timer Intervalls. Der TImer ist zu diesem zeitpunkt nicht aktiv.

onExecute:
- den Dienst am Leben halten mittels..
Delphi-Quellcode:
  while not Terminated do
    ServiceThread.ProcessRequests(true);
onStart:
- Lesen von EInstellungen aus Verzeichnis
- ermitteln von Verzeichnissen
- erstellen von bis zu 200 TTImer Objekten
- bei onCreate modifizierter Timer wird jetzt aktiviert
- die bis zu 200 TTimer Objekte werden nun auch aktiviert

...

So im groben und ganzen war es das schon. Die Frage ist - was macht der Freund hier, das Windows keine Verbindung zum ServiceControler herstellen kann?

Das installieren des DIenstes klappt nämlich, nur nicht der darauf folgende Start..


Habt ihr eine Idee für mich?

Danke

Peter

jaenicke 7. Jan 2012 13:50

AW: Windows Dienst lässt sich nicht starten?! Hilfe!
 
Erstens:
Benutze TApplicationEvents um OnException abzufangen und logge dort inkl. Stacktrace. Denn offenbar fängst du die Fehler ja irgendwo nicht korrekt ab.

Zweitens:
Mit dem Process Monitor solltest du leicht herausfinden können auf welche Datei da versucht wird zuzugreifen.

Und allgemein:
Ich hoffe dir ist klar, dass das aktuelle Arbeitsverzeichnis nicht das deiner Exe ist. Heißt: Wenn du irgendwo vergessen hast den Pfad zu einer Datei, die im selben Verzeichnis liegt, anzugeben, knallt es.
(Aber das gilt für eine normale Anwendung natürlich genauso, fällt nur bei einem Dienst schneller auf.)

// EDIT:
200 TTimer?!? Vielleicht solltest du das Konzept überarbeiten...
Wenn du z.B. einen Timer alle 3 Sekunden ausführst und den zweiten jede Sekunde, kannst du die auch zusammenfassen und z.B. den Code in dem Timer, der alle Sekunde läuft, teilweise nur bei jedem dritten Durchlauf ausführst.

DelphiPeter 7. Jan 2012 14:36

AW: Windows Dienst lässt sich nicht starten?! Hilfe!
 
TApplicationEvents - onException gibts im Windows Dienst nicht.

Der gleiche Code funktioniert in einer Desktop Anwendung völlig schmerzfrei.

Ich denke mit extractfilepath(ParamStr(0)) bin ich genau im Verzeichnis meiner Exe.

Bis zu 200 TTimer, i.d.R. werden es zwischen 1 und 5 sein, die zwischen 3 und 1000 Minuten ausgeführt werden.


Ich kann mir auf das Verhalten des Dienstes keinen Reim bilden... in einer Desktop Anwendung läuft der Mist :?


Hier der EIntrag aus der Windows Ereignisanzeige:

Code:
- <Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
- <System>
  <Provider Name="MyService.exe" />
  <EventID Qualifiers="0">0</EventID>
  <Level>2</Level>
  <Task>0</Task>
  <Keywords>0x80000000000000</Keywords>
  <TimeCreated SystemTime="2012-01-07T14:43:44.000000000Z" />
  <EventRecordID>7038</EventRecordID>
  <Channel>Application</Channel>
  <Computer>Peter-PC</Computer>
  <Security />
  </System>
- <EventData>
  <Data>Der Dienstprozess konnte keine Verbindung mit dem Dienstcontroller herstellen</Data>
  </EventData>
  </Event>

jaenicke 7. Jan 2012 16:09

AW: Windows Dienst lässt sich nicht starten?! Hilfe!
 
Zitat:

Zitat von DelphiPeter (Beitrag 1144809)
TApplicationEvents - onException gibts im Windows Dienst nicht.

Stimmt, ok.

Zitat:

Zitat von DelphiPeter (Beitrag 1144809)
Ich denke mit extractfilepath(ParamStr(0)) bin ich genau im Verzeichnis meiner Exe.

Ja, richtig.

Funktioniert der Start des Dienstes denn, wenn du das OnStart usw. deaktivierst? Im Process Monitor war nichts zu sehen?


Alle Zeitangaben in WEZ +1. Es ist jetzt 18:36 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz