PHP-skript for sikkerhetskopiering og gjenoppretting av en database: Opprett dump - med e-postvarsling

Steg 1:

Vær obs på at større databaser u.U. ikke kan sikkerhetskopieres via skriptet lenger, fordi skriptet evt. støter på serverrestriksjoner!

 

Følgende steg er nødvendig:

1. Opprett en undermappe med navnet "backup" i FTP-hovedmappen til domenet ditt.

2. Lag en PHP-fil (db_backup.php) i mappen med følgende innhold:

 

<?php
######## einstellungen #############################################
$db_name = "IhreDatenBank";
$db_passwd = "IhrDatenBankPasswort";
$downloadlink_erstellen = "ja";

$bestaetigungsmail_senden = "ja";

$bestaetigungsmail_adresse = "IhreMailAdresse";
$bestaetigungsmail_betreff = "[BACKUP] Ihr Backupscript";

$sql_file = "dump_" . $db_name . "_" . date('Ymd_Hi') . ".sql";

####################################################################
################## AB HIER BITTE NICHTS MEHR ÄNDERN!!! ################

### daten überprüfen
if ( $db_name == "IhreDatenBank" or $db_passwd == "IhrDatenBankPasswort" )
{
die("FEHLER: Sie m&uuml;ssen zun&auml;chst Ihre Datenbankdaten im Script eingeben!");
}
if ( file_exists($sql_file) or file_exists($sql_file . ".gz") )
{
die("FEHLER: Das zu erstellende Dump existiert bereits!");
}

## dump erstellen
exec("mariadb-dump -u $db_name -p'$db_passwd' --single-transaction --allow-keywords --complete-insert --insert-ignore --routines --events --force $db_name > $sql_file");
exec("gzip $sql_file");

### größe ermitteln
$datei = $sql_file . ".gz";
$size = filesize($datei);
$i = 0;
while ( $size > 1024 )
{
$i++;
$size = $size / 1024;
}
$fileSizeNames = array(" Bytes", " KiloBytes", " MegaBytes", " GigaBytes", " TerraBytes");
$size = round($size,2);
$size = str_replace(".", ",", $size);
$groesse = "$size $fileSizeNames[$i]";

### nachricht erstellen
$message = "Ihr Backup der Datenbank <b>" . $db_name . "</b> wurde durchgef&uuml;hrt.<br>";
$message .= "Die Gr&ouml;&szlig;e des erstellten Dumps betr&auml;gt <b>" . $groesse . "</b>.<br>";

if ($downloadlink_erstellen == "yes" or $downloadlink_erstellen == "ja" or $downloadlink_erstellen == "1")
{
$link = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'];
$link = str_replace(basename(__FILE__),$datei,$link);
$message .= "Downloadlink: <a href=" . $link . ">" . $datei . "</a>";
}

## nachricht ausgeben
echo $message;

### mail versenden
if ($bestaetigungsmail_senden == "yes" or $bestaetigungsmail_senden == "ja" or $bestaetigungsmail_senden == "1")
{
if(!preg_match( '/^([a-zA-Z0-9])+([.a-zA-Z0-9_-])*@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-]+)+/' , $bestaetigungsmail_adresse))
{
echo "<br>FEHLER: Mail konnte nicht versendet werden, da die Adresse ung&uuml;ltig ist!";
}
else
{
mail($bestaetigungsmail_adresse, $bestaetigungsmail_betreff,
$message,"From: backupscript@{$_SERVER['SERVER_NAME']}\r\n" . "Reply-To: backupscript@{$_SERVER['SERVER_NAME']}\r\n" . "Content-Type: text/html\r\n")
or die("FEHLER: Mail konnte wegen eines unbekannten Fehlers nicht versendet werden");
echo "<br>Best&auml;tigungsmail wurde erfolgreich versandt!";
}
}
?>

 

Vennligst endre disse 3 linjene i kildekoden:

$db_name = "IhreDatenBank";
$db_passwd = "IhrDatenBankPasswort";

$bestaetigungsmail_adresse = "IhreMailAdresse";

Du finner databasenavnet og passordet til databasen i KAS (teknisk administrasjon) under Datenbanken, og setter det inn i feltene "IhreDatenBank" og "IhrDatenBankPasswort". For "IhreMailAdresse" setter du inn e-postadressen du vil at bekreftelsesmailen skal sendes til.

Obs: Opprett en mappebeskyttelse for backup-mappen i KAS (teknisk administrasjon) via Verktøy -> Verzeichnisschutz an! Slik beskytter du databasesikkerhetskopiene dine mot uautoriserte tilganger.

4. Åpne URL-en http://www.ihre-adresse-im-netz.de/backup/db_backup.php. Sikkerhetskopiskriptet starter, lager en sikkerhetskopi av databasen din og kopierer den som en pakket fil med navnet f.eks. dumpDATUM.sql.gz inn i mappen „backup“.

Det er normalt at DB-sikkerhetskopien er mindre enn størrelsen på databasen som vises for deg i phpMyAdmin.
Hvor nyttig syntes du denne veiledningen?

Søk i støtte og FAQ

Seitensuche