![]() |
Ordner Überwachung als Dienst mit NSSM
Hallo zusammen,
ich habe zum rumtesten mal eine Ordnerüberwachung geschrieben und wollte einfach eine kleine Textdatei erzeugen, in die ich hineinschreiben lasse was da gerade passiert. Ich nutze dazu diese Klasse ![]() Das Ganze funktioniert auch, wenn ich die exe direkt per Doppelklick starte. Wenn ich die exe mit nssm als Dienst installiere und starte, steht in der Textdatei nur noch der Eintrag "Reading ini file..." . Wenn ich eine Datei in das zu überwachende Verzeichnis kopiere passiert nichts.
Code:
Weiß jemand evtl. woran das liegen könnte?
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, DirectoryWatch, IniFiles; type TMFORM = class(TForm) procedure FormCreate(Sender: TObject); procedure OnNotify(const Sender: TObject; const Action: TWatchAction; const FileName: string); private { Private declarations } public { Public declarations } end; var MFORM: TMFORM; scanfolder : TStrings; INI : TIniFile; datei : TextFile; Watch : TDirectoryWatch; implementation {$R *.dfm} procedure TMFORM.FormCreate(Sender: TObject); begin assignfile(datei, ExtractFilePath(Application.ExeName) + 'fw.log'); append(datei); writeln(datei, DateTimetoStr(now()) + ' Starting App, Path: ' + ExtractFilePath(Application.ExeName) + ', Filename: ' + ExtractFilename(Application.ExeName)); INI := TINIfile.Create(ExtractFilePath(Application.ExeName) + 'dir.ini'); scanfolder := TStringList.Create; INI.ReadSection('ScanDirectory', scanfolder); writeln(datei, DateTimetoStr(now()) + ' Reading ini file -> scanfolder: ' + scanfolder[0]); closeFile(datei); Watch := TDirectoryWatch.Create; Watch.WatchOptions := [woFileName]; Watch.WatchActions := [waAdded, waRemoved, waModified, waRenamedOld, waRenamedNew]; Watch.Directory := scanfolder[0]; Watch.OnNotify := OnNotify; Watch.Start; end; procedure TMFORM.OnNotify(const Sender: TObject; const Action: TWatchAction; const FileName: string); begin case Action of waAdded: begin assignfile(datei, ExtractFilePath(Application.ExeName) + 'fw.log'); append(datei); writeln(datei, DateTimetoStr(now()) + ' ' + FileName); closeFile(datei); end; end; end; LG Mirko |
AW: Ordner Überwachung als Dienst mit NSSM
Erstmal warum eine Form im Dienst?
Dienste sind standardmäßig nicht-visuell. TDataModule oder TService, wenn man es gleich richtig macht. Und warum NSSM? Mit Delphi einen Service zu erstellen ist nicht schwer. Alles was ich als Zusatzversprechen auf der Webseite von NSSM lesen konnte, das macht Windows von sich aus. Dienst zu debuggen ist jetzt nicht ganz sooo einfach, aber da du schon sowas wie ein Logging hast, wäre es kein Problem dort auch weitere Stellen zu prüfen, wie z.B. die Erstellung/Arbeit in der verwendeten Komponente. |
AW: Ordner Überwachung als Dienst mit NSSM
Ich habe jetzt einen Service mit Delphi erstellt, das ging wirklich sehr einfach.
Ich habe den Service mit sc create ServiceName binpath="xy" installiert aber er bleibt im Status "Starting" hängen. LG Mirko |
AW: Ordner Überwachung als Dienst mit NSSM
Delphi-Dienste kann man einfach installieren, indem man die Exe mit dem Kommandoparameter "/install" aufruft. Zum Deinstallieren heißt der Parameter folgerichtig "/uninstall". Und wie schon erwähnt sollte man auf Formulare verzichten. Außerdem sollte man im OnExecute des Service folgendes aufrufen:
Delphi-Quellcode:
while not Terminated do
ServiceThread.ProcessRequests(True); |
AW: Ordner Überwachung als Dienst mit NSSM
Ja hat geklappt danke.
LG Mirko |
AW: Ordner Überwachung als Dienst mit NSSM
Okay der Service läuft aber wenn ich eine größere Datei in das zu überwachende Verzeichnis kopiere müsste ich erstmal warten, bis diese fertig Kopiert ist, bevor ich damit etwas machen kann.
Der letzte Notify der im Kopiervorgang ausgelöst wird, ist FILE_NOTIFY_CHANGE_LAST_WRITE. In meinem Logfile taucht er zwei mal auf, ich denke einmal am Anfang des Kopierens und einmal am Ende. Kann ich irgendwie prüfen, ob der Kopiervorgang noch läuft oder gibt es in ReadDirectoryChangesW irgendeine Meldung wenn der Kopiervorgang abgeschlossen ist? LG Mirko Das hat nichts mehr mit dem Dienst zu tun, ich stelle die Frage lieber nochmal separat. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:40 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-2025 by Thomas Breitkreuz