AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Delphi Nur 1 Instanz pro _System_ erlauben?
Thema durchsuchen
Ansicht
Themen-Optionen

Nur 1 Instanz pro _System_ erlauben?

Ein Thema von blackdrake · begonnen am 5. Sep 2008 · letzter Beitrag vom 5. Sep 2008
Antwort Antwort
Seite 1 von 2  1 2      
blackdrake

Registriert seit: 22. Aug 2003
Ort: Bammental
618 Beiträge
 
Delphi 10.3 Rio
 
#1

Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 01:55
Hallo.

Ich verwende zum Verhindern von 2 Programminstanzen derzeit folgenden Code: http://www.delphipraxis.net/internal_redirect.php?t=136 .

Dieser hat eigentlich immer gut seine Dienste erfüllt, jedoch bin ich jetzt auf ein Problem gestoßen.

Ich arbeite an einem Programm, das mit dem System startet und eine Datei ständig liest und schreibt. Es ist nur 1 Programminstanz erlaubt. Läuft eine Weitere, kommen sich die Instanzen durch die Lese/Schreibzugriffe sowie den Berechnungen dazwischen in die Quere und es kann zu Fehlern (auch Datenfehlern durch Fehlberechnungen) kommen.

Das Problem besteht bei der Benutzerumschaltung von Windows. Loggt man sich als 2ter Benutzer gleichzeitig ein, kann das Programm Problemlos mit dem Autostart hochgefahren werden - die Instanzprüfung via Mutex'es läuft nur auf Benutzerebene, nicht auf Systemebene.

Gibt es eine systemglobale Alternative zu den Mutex? Wenn ja, ist diese dann dem anderen Code vorzuziehen?

Ich persönlich würde stets dazu tendieren, immer die Instanz systemglobal anstelle benutzerlokal zu sperren, sobald das Programm Daten aus einer bestimmten Datei liest und schreibt. Es könnte ja ansonsten passieren, dass sich die Leseprozesse und Schreibprozesse durch Zufall überkreuzen (sofern eine Instanz des anderen Benutzers die Datei z.B. updated und somit für längere Zeit in diese schreibt). Eure Meinung?

Gruß
blackdrake
Daniel Marschall
  Mit Zitat antworten Zitat
Benutzerbild von _frank_
_frank_

Registriert seit: 21. Feb 2003
Ort: Plauen / Bamberg
922 Beiträge
 
Delphi 3 Professional
 
#2

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 02:05
warum öffnest du nicht die Datei exklusiv und prüfst das ggf. beim starten einer weiteren Instanz?
ggf. kannst du ja eine separate Datei erstellen und beim beenden löschen.

HTH Frank
  Mit Zitat antworten Zitat
blackdrake

Registriert seit: 22. Aug 2003
Ort: Bammental
618 Beiträge
 
Delphi 10.3 Rio
 
#3

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 02:11
Zitat von _frank_:
warum öffnest du nicht die Datei exklusiv und prüfst das ggf. beim starten einer weiteren Instanz?
ggf. kannst du ja eine separate Datei erstellen und beim beenden löschen.

HTH Frank
Exklusives Öffnen: Habe ich mir auch schon mal überlegt. (Eventuell habe es auch mal in einem anderen Projekt implementiert? Werde ich nochmal nachschauen.) Das Problem ist, dass die 2te Instanz zumindestens eine Meldung ausgibt, wenn es zu einem Schreibfehler kommt.

Beim Starten prüfen: Das ist ja genau das Problem. Der zweite Benutzer des Systems sieht nicht, wenn der erste Benutzer eine Mutex hat. Also kann ich schlecht auf eine Zweitinstanz prüfen.

Die separate Datei wäre dann ein Lockfile. Sowas wird meines Wissens bei Linux-Servern (Apache) verwendet, jedoch ist dies für Client-Software bedenklich, da die Software unbrauchbar wird, wenn man sie durch Stromausfall oder den Taskmanager beendet. (Unter der Annahme, der DAU Benutzer weiß nicht, dass eine Lockfile gelöscht werden muss)
Daniel Marschall
  Mit Zitat antworten Zitat
Dax
(Gast)

n/a Beiträge
 
#4

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 02:13
Wie wäre es mit Named Pipes oder MM-Files?
  Mit Zitat antworten Zitat
Benutzerbild von _frank_
_frank_

Registriert seit: 21. Feb 2003
Ort: Plauen / Bamberg
922 Beiträge
 
Delphi 3 Professional
 
#5

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 02:24
Zitat von blackdrake:
Exklusives Öffnen: Habe ich mir auch schon mal überlegt. (Eventuell habe es auch mal in einem anderen Projekt implementiert? Werde ich nochmal nachschauen.) Das Problem ist, dass die 2te Instanz zumindestens eine Meldung ausgibt, wenn es zu einem Schreibfehler kommt.

Beim Starten prüfen: Das ist ja genau das Problem. Der zweite Benutzer des Systems sieht nicht, wenn der erste Benutzer eine Mutex hat. Also kann ich schlecht auf eine Zweitinstanz prüfen.

Die separate Datei wäre dann ein Lockfile. Sowas wird meines Wissens bei Linux-Servern (Apache) verwendet, jedoch ist dies für Client-Software bedenklich, da die Software unbrauchbar wird, wenn man sie durch Stromausfall oder den Taskmanager beendet. (Unter der Annahme, der DAU Benutzer weiß nicht, dass eine Lockfile gelöscht werden muss)
nicht nur die datei anlegen, sondern auch gegen Zugriff durch andere Prozesse sperren (Exklusiv öffnen halt ), ist imho das gleiche wie Memory-Mapped-Files...und dann schauen, ob die datei gesperrt ist. ist der prozess tot kann die datei geöffnet werden und die "2. Instanz" ist erlaubt.

siehe dwShareMode in [MSDN] CreateFile
den Wert auf 0 setzen sollte das bewerkstelligen. wie du testen kannst, steht auch drin

Gruß Frank
  Mit Zitat antworten Zitat
Benutzerbild von nicodex
nicodex

Registriert seit: 2. Jan 2008
Ort: Darmstadt
286 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 07:56
Zitat von blackdrake:
Gibt es eine systemglobale Alternative zu den Mutex?
Es gibt systemglobale Mutexe (mit dem Präfix "Global\").
Wird nur nicht von allen Windows-Versionen unterstützt (deren Support längst ausgelaufen ist).
  Mit Zitat antworten Zitat
QuickAndDirty

Registriert seit: 13. Jan 2004
Ort: Hamm(Westf)
1.927 Beiträge
 
Delphi 12 Athens
 
#7

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 08:32
-Bei start prüfen ob der Prozess läuft (Prozessliste abgreifen gucken ob 2 Einträge drinn sind).

ODER

-Das System richtig benutzen, d.h. die Datei die den Konflikt verursacht in den Ordner Eigene Dateien legen-

ODER

-(InterProcessCommunication)IPC Clientstarten,nach IPC Server fragen, wenn der fehlt dann selbst IPC-Server starten.
Andreas
Monads? Wtf are Monads?
  Mit Zitat antworten Zitat
Benutzerbild von SubData
SubData

Registriert seit: 14. Sep 2004
Ort: Stuhr
1.078 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 08:56
Was ist denn gegen einen globalen Mutex einzuwenden?

Delphi-Quellcode:
initialization
  hApp := CreateMutex(nil, True, 'Global\MYAPP');
  if GetLastError = ERROR_ALREADY_EXISTS then
  begin
    MessageDlg('Die Software kann nur einmal gestartet werden!', mtError, [mbOK],0);
    Halt;
  end;

finalization
  if hApp <> 0 then CloseHandle(hApp);

Edit: Da dieser Code ja für die Lib vorgeschlagen wurde ein Nachtrag.
Das Handle sollte beim Beenden natürlich wieder freigegeben werden
Ronny
/(bb|[^b]{2})/
  Mit Zitat antworten Zitat
Benutzerbild von nicodex
nicodex

Registriert seit: 2. Jan 2008
Ort: Darmstadt
286 Beiträge
 
Delphi 2007 Professional
 
#9

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 08:58
Zitat von QuickAndDirty:
Bei start prüfen ob der Prozess läuft (Prozessliste abgreifen gucken ob 2 Einträge drinn sind).
Der jeweilige Benutzer hat möglicherweise nicht die Rechte, um alle Prozesse aufzulisten, bzw. deren relevate Eigenschaften zu lesen.
Zudem sind die Eigenschaften eines Prozesses ohne weitere Einschränkungen nicht ausreichend, um eine hinreichend genaue Bestimmung vonehmen zu können.

Zitat von QuickAndDirty:
Das System richtig benutzen, d.h. die Datei die den Konflikt verursacht in den Ordner Eigene Dateien legen
Jeder Benutzer hat seine "Eigenen Dateien". Es ist auf einem Mehrbenutzersystem gar nicht so einfach _ein_ Verzeichnis zu finden, auf das _alle_ Benutzer zugreifen können.

Zitat von QuickAndDirty:
(InterProcessCommunication)IPC Clientstarten,nach IPC Server fragen, wenn der fehlt dann selbst IPC-Server starten.
Warum eine komplette Client-/Server-Implementation, wenn ein globales Objekt den gleichen Zweck erfüllt?
  Mit Zitat antworten Zitat
blackdrake

Registriert seit: 22. Aug 2003
Ort: Bammental
618 Beiträge
 
Delphi 10.3 Rio
 
#10

Re: Nur 1 Instanz pro _System_ erlauben?

  Alt 5. Sep 2008, 18:33
Hallo. Vielen Dank für eure Antworten. Ich werde in meinen Projekten ggf. auf die exklusiven Dateizugriffe achten oder, sofern erforderlich, nur in Benutzerverzeichnisse schreiben. Der Hinweis mit dem "Global\" bei den Mutex habe ich gesucht. Er wird vielleicht auch Verwendung finden. Den Code von SubData habe ich für die CodeLib vorgeschlagen.
Daniel Marschall
  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 10:19 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