![]() |
Datenbank: Firebird • Version: 2.5.1 • Zugriff über: UniDAC
Firebird - DB Backup
Firebird Backup mit Hilfe einer .bat Datei.
Code:
Aus dem Programm heraus die Datenbank vom Server als Backup sichern, sowie die lokale Datenbank aus dem Programm EXE Verzeichnis.
REM http://www.destructor.de/firebird/gbak.htm
REM ------------------------------------------ REM evtl. bestehende LOG Datei löschen del "C:\ProgramData\Anwendungsverzeichnis\backup\database.log" REM Backup starten "C:\ProgramData\Anwendungsverzeichnis\backup\gbak.exe" -v -t -user sysdba -password masterkey -y "C:\ProgramData\Anwendungsverzeichnis\backup\database.log" "K:\Ordnername\Programmbezeichnung\Win32\Debug\Database.fdb" "C:\ProgramData\Anwendungsverzeichnis\backup\BACKUP.fbk" REM DOS Fenster nicht schließen PAUSE
Delphi-Quellcode:
Das funktioniert 'jetzt'. Erst wollte ich eine andere Frage stellen.
var
BackupDirectory, Quelle, Ziel, Parameter : String; begin BackupDirectory := 'C:\ProgramData\Anwendungsverzeichnis\backup\'; with SaveDialog do begin FileName := 'backup'; Filter := 'database (*.fbk)|*.fbk'; DefaultExt := '*.fbk'; InitialDir := BackupDirectory; end; Ziel := '"' + SaveDialog.FileName + '"'; if Datenmodul.UniConnection.Server <> '' // bei der lokalen DB ist der Server Eintrag leer then Quelle := '"' + Datenmodul.UniConnection.Server + ':' + Datenmodul.UniConnection.Database + '"' else Quelle := '"' + ExtractFilePath(ParamStr(0)) + 'Database.fdb' + '"'; Parameter := '-v -t -user sysdba -password masterkey '+ Quelle +' '+ Ziel; ShellExecute(0,nil,PChar(BackupDirectory + 'gbak.exe'),PChar(Parameter),nil,SW_SHOW); end; Im Verzeichnis ...\ProgramData\Anwendungsverzeichnis\backup\ Ordner befindet sich die gbak.exe, zusätzlich hatte ich dort die 'fbclient.dll' mit drinnen damit hat der lokale Backup nicht funktioniert, jetzt habe ich die 'gds32.dll' reinkopiert und alles klappt wunderbar. Meine Frage jetzt: Gibt es eine Übersicht wann die 'fbclient.dll' & wann die 'gds32.dll' genommen werden sollte oder sollte ich generell einfach beide Dateien in den Ordner packen? PS: Zusätzlich läuft local auch noch ein Firebird Server als Dienst. |
AW: Firebird - DB Backup
Zu welcher Version gehört die gbak.exe? Vermutlich zu einer Interbase-Version
|
AW: Firebird - DB Backup
vermute ich auch.. kontrollier doch mal die Version von gbak - sollte eigentlich identisch mit der fbClient.dll sein, dann klappts auch damit...
Grüße |
AW: Firebird - DB Backup
/confused
Die gbak.exe gehört doch zur Firebird Version (Ordner bin)? Es wird immer verwirrender... ![]() |
AW: Firebird - DB Backup
sicher.. bist Du dir auch 100% sicher, dass Du die aus dem korrekten Verzeichnis hast? Wie gesagt, schau dir mal die Version der gbak an...
Hast Du ggf. in anderen Verzeichnissen (system32 usw.) noch Altbestände von gds32.dll oder fbclient.dll? Grüße |
AW: Firebird - DB Backup
hmmm, den Firebird Dienst beendet, Lokal im Ordner C:\Windows\SysWOW64 eine gds32.dll gefunden & umbenannt.
gbak.exe (V. 2.5.1) funktioniert anscheinend nur in Verbindung mit der gds32.dll Die gds32 Datei kann hierbei sein: - Interbase Client 10.0.1.335 - Firebird SQL Server 2.5.1.26351 |
AW: Firebird - DB Backup
Such mal nach weitern gbak.exe Dateien
|
AW: Firebird - DB Backup
?
Ich rufe diese eine doch direkt auf: ShellExecute(0,nil,PChar(BackupDirectory + 'gbak.exe'),PChar(Parameter),nil,SW_SHOW); und eigentlich will ich ja auch nur Wissen welche Datei man mitgeben muss: gds32.dll oder fbclient.dll Ich habe herausgefunden das es mit den gds32.dll immer klappt wenn diese im Verzeichnis der gbak.exe liegt. Nehme ich dort eine fbclient.dll dann funktioniert die lokale Sicherung der lokalen DB nicht. |
AW: Firebird - DB Backup
ah warte mal...
kannst Du mal eben deinen Source ändern: Wenn kein Server da ist, mach dennoch eine Serververbindung zu localhost. Geht dann die fbclient? Handelt es sich bei dem OS zufällig um Win 7? Grüße |
AW: Firebird - DB Backup
alles geändert. Hatte die gbak.exe in einem anderen Verzeichnis (warum mache ich sowas :roll: ), jetzt habe ich die ins Anwendungsverzeichnis gepackt und alles funktioniert, Win7 sowie XP. Die Fett markierten Dateien aus dem Anwendungsverzeichnis werden anscheinend für das Backup benötigt, zumindest hat XP danach gebettelt.
fbclient.dll firebird.conf firebird.msg ib_util.dll icudt30.dll icuin30.dll icuuc30.dll Microsoft.VC80.CRT.manifest msvcp80.dll msvcr80.dll Ordner: intl sowie udf Danke an alle für Ihre Hilfe & Lesen meines selbst gemachten SPAM´s |
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:02 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 by Thomas Breitkreuz