Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Ordner Überwachung als Dienst mit NSSM (https://www.delphipraxis.net/204916-ordner-ueberwachung-als-dienst-mit-nssm.html)

oakley 13. Jul 2020 22:00

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 https://www.developpez.net/forums/at...directorywatch

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:
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;
Weiß jemand evtl. woran das liegen könnte?

LG

Mirko

himitsu 13. Jul 2020 22:58

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.

oakley 14. Jul 2020 09:07

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

DeddyH 14. Jul 2020 09:27

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);

oakley 14. Jul 2020 09:44

AW: Ordner Überwachung als Dienst mit NSSM
 
Ja hat geklappt danke.

LG

Mirko

oakley 14. Jul 2020 15:29

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 16: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