Kopia zapasowa bazy danych MySQL: Różnice pomiędzy wersjami
Z ToProste
m |
m |
||
Linia 19: | Linia 19: | ||
<syntaxhighlight lang="php"> | <syntaxhighlight lang="php"> | ||
<?php | <?php | ||
+ | $time = time(); | ||
$dbhost = "localhost"; | $dbhost = "localhost"; | ||
$dbuser = "uzytkownik"; | $dbuser = "uzytkownik"; | ||
Linia 25: | Linia 26: | ||
$backupFolder = 'backupDB/'; | $backupFolder = 'backupDB/'; | ||
− | $backupTime = date("YmdHis"); | + | $backupTime = date("YmdHis", $time); |
if (!is_dir($backupFolder)) mkdir($backupFolder, 0777, true); | if (!is_dir($backupFolder)) mkdir($backupFolder, 0777, true); | ||
chmod($backupFolder, 0777); | chmod($backupFolder, 0777); | ||
− | $backupFile = $backupFolder.'bakDB_'.$dbname.'_'.$backupTime | + | $backupFile = $backupFolder.'bakDB_'.$dbname.'_'.$backupTime; |
− | system("/usr/local/mysql/bin/mysqldump -u$dbuser -p$dbpass $dbname > $backupFile"); | + | system("/usr/local/mysql/bin/mysqldump -u$dbuser -p$dbpass $dbname > $backupFile".".sql"); |
?> | ?> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Linia 39: | Linia 40: | ||
<!--Jeśli nie mamy dostępu do funkcji system(), pozostaje jeszcze inne rozwiązanie.--> | <!--Jeśli nie mamy dostępu do funkcji system(), pozostaje jeszcze inne rozwiązanie.--> | ||
+ | |||
+ | Źródła: [https://dev.mysql.com/doc/refman/5.1/en/mysqldump.html] | ||
+ | |||
+ | |||
+ | [[Kategoria:Uzupełnić]] |
Wersja z 19:33, 25 lut 2014
Spis treści
mysqldump
mysqldump jest to program używany do robienia kopii zapasowej bazy MySQL. Zrzut bazy może być zapisany do pliku SQL, CSV, XML, itp. Kopia bazy w formacie SQL zawiera takie polecenia jak: DROP table, CREATE table i INSERT into źródłowej bazy danych, dzięki czemu jej wykonanie w docelowej bazie powoduje przywrócenie danych z kopii.
mysqldump -u[uzytkownik] -p[haslo] [nazwa_bazy] > plik.sql
kopia wybranej bazy
mysqldump -uuzytkownik -phaslo nazwa_bazy > kopia_bazy_nazwa_bazy.sql
kopia wybranej tabeli bazy
mysqldump -uuzytkownik -phaslo nazwa_bazy nazwa_tabeli > kopia_nazwa_tabeli_nazwa_bazy.sql
kopia kilku baz danych
mysqldump -uuzytkownik -phaslo --databases baza1 baza2 baza3 > kopia_kilku_baz.sql
kopia wszystkich baz danych
mysqldump -uuzytkownik -phaslo --all-databases > kopia_wszystkich_baz.sql
Skrypt PHP backup MySQL
<?php $time = time(); $dbhost = "localhost"; $dbuser = "uzytkownik"; $dbpass = "haslo"; $dbname = "nazwa_bazy"; $backupFolder = 'backupDB/'; $backupTime = date("YmdHis", $time); if (!is_dir($backupFolder)) mkdir($backupFolder, 0777, true); chmod($backupFolder, 0777); $backupFile = $backupFolder.'bakDB_'.$dbname.'_'.$backupTime; system("/usr/local/mysql/bin/mysqldump -u$dbuser -p$dbpass $dbname > $backupFile".".sql"); ?>
Aby skrypt działał, niezbędny jest dostęp do funkcji system(), która ze względów bezpieczeństwa może być zablokowana. Listę zablokowanych funkcji hostingu można sprawdzić używając phpinfo(), w wierszu disable_functions.
Źródła: [1]