Kopia zapasowa bazy danych MySQL: Różnice pomiędzy wersjami

Z ToProste
Skocz do: nawigacji, wyszukiwania
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.'.sql';
+
$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 18:33, 25 lut 2014

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]