Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Delphi Alle EXE' n einer Anwendung zum Zeitpunkt X beenden... (https://www.delphipraxis.net/185491-alle-exe-n-einer-anwendung-zum-zeitpunkt-x-beenden.html)

himitsu 16. Jun 2015 15:27

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Eventuell kann Firebird und deine DB-Komponenten auch mit Notification/Callbacks umgehen.

Sonst fragt der Client ja beim Server an, aber bei Notifications wendet sich der Server an einen/alle Clienten und schickt denen eine Nachricht.
Beim Empfang einer Nachricht kannst du das auswerten und z.B. auf den Text "Beenden" reagieren.

Ich hatte das letztens bei uns so umgesetzt, daß man z.B. eine MessageBox anzeigen kann (User+Message, bzw. All+Message) oder eben ein Shutdown-Befehl (Timeout+Message)
"Programm wird in 5 Mnuten beendet. Bitte speichern." oder Dregleichen.

Die Befehle sind einfach wie eine Stringliste hinterlegt, da die Notification ein String ist.
Delphi-Quellcode:
Command=Shutdown;Timeout=300;Message=Wartungsupdate


[edit]
Und ja, manchmal hängen die Events/Notifications etwas, oder arbeiten garnicht.

mkinzler 16. Jun 2015 15:38

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Bei Firebird Events benachrichtigt der Server die Clients, welche sich für dafür beim Server registriert haben.

dataspider 16. Jun 2015 20:10

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Zitat:

Zitat von himitsu (Beitrag 1305302)
Eventuell kann Firebird und deine DB-Komponenten auch mit Notification/Callbacks umgehen.

Ich denke - wie mkinzler auch - dass die Events (POST_EVENT) von Firebird vom Server ausgehen und damit wohl genau das tun, was du beschreibst.
Ich bin nun sowieso fast fertig und kann mit der Lösung gut leben...

Nochmals Danke

Frank

Dejan Vu 17. Jun 2015 07:21

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Ich habe dieses Problem so gelöst, das die Anwender die EXE einfach nicht direkt starten können. Sie starten eine Batch-Datei, die aus dem Netz die EXE lokal kopiert und dann ausführt. So kann ich Ruhe meine Updates einspielen und beim nächsten Start haben alle Anwender automatisch die aktuelle EXE.

Bei dieser Vorgehensweise reicht ein "Es ist eine neue Version verfügbar, welche beim nächsten Start automatisch geladen wird." als Nachricht. Alternativ kann man die Batch-Datei durch einen UI-gepimpten 'Loader' ersetzen, der irgendwelche Releasenotes anzeigt, sofern die EXE neueren Datums ist.

Nachrichten habe ich einmal über Mailslots verschickt. Ich fand es blöd, dafür eine Tabelle vorzuhalten. Für 'offline' und 'latest News' sowie eine History (wer wann gelesen) ist das aber durchaus sinnvoll.

dataspider 17. Jun 2015 08:52

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Zitat:

Zitat von Dejan Vu (Beitrag 1305370)
Ich habe dieses Problem so gelöst, das die Anwender die EXE einfach nicht direkt starten können. Sie starten eine Batch-Datei, die aus dem Netz die EXE lokal kopiert und dann ausführt. So kann ich Ruhe meine Updates einspielen und beim nächsten Start haben alle Anwender automatisch die aktuelle EXE.

Das hatte ich auch mal. Ich hatte dafür eine eigene AppStart.EXE und eine INI mit allen Parametern für den Abgleich.

Mein eigentliches Problem ist aber, dass ich zumindest bei diesem Projekt sicherstellen muss, dass während des DB-Updates alle Benutzer von der Datenbank getrennt sind.

Danke

Frank

mm1256 17. Jun 2015 09:28

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Zitat:

Zitat von dataspider (Beitrag 1305380)
Mein eigentliches Problem ist aber, dass ich zumindest bei diesem Projekt sicherstellen muss, dass während des DB-Updates alle Benutzer von der Datenbank getrennt sind.

....und während des Updatevorganges kein ReConnect eines Clients stattfinden darf.

Dieses Problem löse ich wie folgt: Auf dem Server liegt eine Tabelle mit Login-Logout-Informationen jedes Clients, physikalischer Dateiname "Logbuch". Darin wird protokolliert, wann User im Netzwerk ein Programm starten, und wann (und ob) sie es wieder ordnungsgemäß beenden. Bei einem Update ohne strukturelle Änderungen an der DB (ein quasi On-the-Fly-Update) bleibt die Struktur dieser Tabelle gleich. Wenn aber - so wie vermutlich auch bei dir - strukturelle Änderungen an den Datenbanken vorgenommen werden (müssen) gehe ich wie folgt vor:

- der DB-Server-Dienst wird beendet
- TCP/IP wird im DB-Server deaktiviert
- der DB-Server wird mit lokalem Zugriff (named Pipe) gestartet
- die Struktur der Logbuch-Tabelle wird geändert, d.h. das Feld bzw. der Feldname mit der Versionsnummer wird umbenannt
- weitere Strukturänderungen werden durchgeführt
- das Update (Programmdateien) wird installiert
- der DB-Server wird mit aktiviertem TCP/IP neu gestartet

Aufgrund Verwendung einer persistenten Feldliste können nun ältere Programmversionen generell nicht mehr am System angemeldet werden, weil ja das Feld (der Feldname) mit der neuen Versionsnummer bei der Anmeldung nicht gefunden wird. Die Exception wird behandelt und der User darauf hingewiesen, dass er versucht hat, sich mit einer alten Programmversion am neuen Datenbestand anzumelden. Das funktioniert immer, sowohl bei lokalen auf dem Client liegenden Programmdateien als auch bei shared auf dem Server liegenden Programmdateien.

Mavarik 17. Jun 2015 09:52

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Früher habe ich auch den Trick mit der Batch Datei gemacht...

Warum legst Du nicht einfach eine Datei hin DeinProgramm.Upd
Beim Start testest Du ab ob die Datei da ist und wenn ja starttest Du per Shellexecute ein Renamer der die aktuelle Version schließt und dann
DeinProgramm.exe löscht und DeinProgramm.Upd renamed auf *.exe.

Mavarik

dataspider 17. Jun 2015 12:19

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Zitat:

Zitat von mm1256 (Beitrag 1305383)
- der DB-Server-Dienst wird beendet
- TCP/IP wird im DB-Server deaktiviert
...

Fehlt am Anfang als Erstes: Alle laufenden Anwendungen, die auf die Datenbank zugreifen, werden beendet.
Nur das war mein Problem.
Dann erfolgt ein ShutDown des Firebird - Servers...

Trotzdem Danke. Anregungen sind immer wertvoll!

Zitat:

Zitat von Mavarik (Beitrag 1305387)
Warum legst Du nicht einfach eine Datei hin DeinProgramm.Upd
Beim Start testest Du ab ob die Datei da ist und wenn ja starttest Du per Shellexecute ein Renamer der die aktuelle Version schließt und dann
DeinProgramm.exe löscht und DeinProgramm.Upd renamed auf *.exe.
Mavarik

siehe #15...
Ohne "Zwangstrennung" geht es nicht, dennoch soll diese "sanft" erfolgen :)

Frank

mkinzler 18. Jun 2015 09:36

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Ich würde nicht den Firebird Server beenden, sondern die Datenbank in den Wartungsmodus versetzen.

dataspider 18. Jun 2015 10:14

AW: Alle EXE' n einer Anwendung zum Zeitpunkt X beenden...
 
Zitat:

Zitat von mkinzler (Beitrag 1305517)
Ich würde nicht den Firebird Server beenden, sondern die Datenbank in den Wartungsmodus versetzen.

Genau das macht ja ShutDown des Firebird Servers.
Ich will ja auch die Update - Scripts einspielen.

Frank


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:20 Uhr.
Seite 2 von 2     12   

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