Einzelnen Beitrag anzeigen

nahpets
(Gast)

n/a Beiträge
 

Re: bekomme den service nicht zum laufen...

  Alt 22. Okt 2008, 16:43
Versuch's mal damit:
Delphi-Quellcode:
unit Unit1;

interface


uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, SvcMgr, Dialogs;


type
  TTestservice = class(TService)
    procedure ServiceStart(Sender: TService; var Started: Boolean);
    procedure ServiceExecute(Sender: TService);
  private
    { Private-Deklarationen }
  public
    function GetServiceController: TServiceController; override;
    { Public-Deklarationen }
  end;


var
  Testservice: TTestservice;
  LogFile: TStringList;


implementation


{$R *.DFM}


const LogFileName = 'c:\test\Service_log.txt';


procedure ServiceController(CtrlCode: DWord); stdcall;
begin
  Testservice.Controller(CtrlCode);
end;


function TTestservice.GetServiceController: TServiceController;
begin
  Result := ServiceController;
end;


procedure TTestservice.ServiceExecute(Sender: TService);
begin
  while not Terminated do
  begin
    ServiceThread.ProcessRequests(true);
    // Sleep(5000);
    LogFile.Add(DateTimeToStr(Now)+' OnExecute');
    LogFile.SaveToFile(LogFileName);
  end;
end;


procedure TTestservice.ServiceStart(Sender: TService; var Started: Boolean);
begin
  LogFile.Add(DateTimeToStr(Now)+' Service gestartet');
  LogFile.SaveToFile(LogFileName);
end;

initialization
  LogFile:=TStringList.Create;

finalization
  LogFile.Free;

end.
Die Stringliste gehört jetzt nicht mehr zur Klasse, sondern ist eine globale Variabel. Vermutlich ist das nicht sauber und nicht threadsicher. In meinen Services mach' ich das Logging so:
Delphi-Quellcode:
procedure TSystemmonitor.ErrorLog(sError : String; iDebugLevel : Integer);
Var
          f : TextFile;
begin
  If iDebugLevel <= Self.DebugLevel Then Begin
    AssignFile(f,LogFileName);
    If FileExists(LogFileName) Then Append(f) Else ReWrite(f);
    WriteLn(f,DateToStr(Now) + ' ' + TimeToStr(Now) + ' ' + sError);
    CloseFile(f);
  End;
end;

procedure TSystemmonitor.ServiceStart(Sender: TService; var Started: Boolean);
begin
  Self.ErrorLog('ServiceStart=' + IntToStr(Ord(Started)),1);
end;
Wenn ein Service tagelang läuft und viel protokolliert, dürfte eine Stringliste auf Dauer zu einem Speicherfresser mutieren.
  Mit Zitat antworten Zitat