AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird - DB Backup

Ein Thema von user0815 · begonnen am 24. Sep 2012 · letzter Beitrag vom 24. Sep 2012
Antwort Antwort
Benutzerbild von user0815
user0815

Registriert seit: 5. Okt 2007
331 Beiträge
 
Delphi XE2 Professional
 
#1

Firebird - DB Backup

  Alt 24. Sep 2012, 10:07
Datenbank: Firebird • Version: 2.5.1 • Zugriff über: UniDAC
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.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 10:13
Zu welcher Version gehört die gbak.exe? Vermutlich zu einer Interbase-Version
Markus Kinzler
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.380 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 10:18
vermute ich auch.. kontrollier doch mal die Version von gbak - sollte eigentlich identisch mit der fbClient.dll sein, dann klappts auch damit...

Grüße
  Mit Zitat antworten Zitat
Benutzerbild von user0815
user0815

Registriert seit: 5. Okt 2007
331 Beiträge
 
Delphi XE2 Professional
 
#4

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 10:44
/confused

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

http://sourceforge.net/projects/fire...2.zip/download
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.380 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 10:46
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
  Mit Zitat antworten Zitat
Benutzerbild von user0815
user0815

Registriert seit: 5. Okt 2007
331 Beiträge
 
Delphi XE2 Professional
 
#6

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 11:10
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
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 11:15
Such mal nach weitern gbak.exe Dateien
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von user0815
user0815

Registriert seit: 5. Okt 2007
331 Beiträge
 
Delphi XE2 Professional
 
#8

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 11:21
?

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.
  Mit Zitat antworten Zitat
Lemmy

Registriert seit: 8. Jun 2002
Ort: Berglen
2.380 Beiträge
 
Delphi 10.3 Rio
 
#9

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 11:23
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
  Mit Zitat antworten Zitat
Benutzerbild von user0815
user0815

Registriert seit: 5. Okt 2007
331 Beiträge
 
Delphi XE2 Professional
 
#10

AW: Firebird - DB Backup

  Alt 24. Sep 2012, 12:14
alles geändert. Hatte die gbak.exe in einem anderen Verzeichnis (warum mache ich sowas ), 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
  Mit Zitat antworten Zitat
Antwort Antwort


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 20:09 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