Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Firebird - DB Backup (https://www.delphipraxis.net/170568-firebird-db-backup.html)

user0815 24. Sep 2012 10:07

Datenbank: Firebird • Version: 2.5.1 • Zugriff über: UniDAC

Firebird - DB Backup
 
Firebird Backup mit Hilfe einer .bat Datei.

Code:
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
Aus dem Programm heraus die Datenbank vom Server als Backup sichern, sowie die lokale Datenbank aus dem Programm EXE Verzeichnis.
Delphi-Quellcode:
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;
Das funktioniert 'jetzt'. Erst wollte ich eine andere Frage stellen.
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.

mkinzler 24. Sep 2012 10:13

AW: Firebird - DB Backup
 
Zu welcher Version gehört die gbak.exe? Vermutlich zu einer Interbase-Version

Lemmy 24. Sep 2012 10:18

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

user0815 24. Sep 2012 10:44

AW: Firebird - DB Backup
 
/confused

Die gbak.exe gehört doch zur Firebird Version (Ordner bin)? Es wird immer verwirrender...

http://sourceforge.net/projects/fire...2.zip/download

Lemmy 24. Sep 2012 10:46

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

user0815 24. Sep 2012 11:10

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

mkinzler 24. Sep 2012 11:15

AW: Firebird - DB Backup
 
Such mal nach weitern gbak.exe Dateien

user0815 24. Sep 2012 11:21

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.

Lemmy 24. Sep 2012 11:23

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

user0815 24. Sep 2012 12:14

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