whitelex
Постоялец
- Регистрация
- 5 Апр 2008
- Сообщения
- 59
- Реакции
- 4
- Автор темы
- #1
Предлагаю такой несложный скрипт для создания резервных копий БД и отправки файла на Е-mail пользователя.
Если скрипт запускается создает копии и отправляет сообщение на ящик, то создаем задание в cron job, пример:
PHP:
<?php
#---Настроки---#
$user = ""; // Имя пльзователя БД
$pwd = ""; // Пароль для подключения БД
$db = ""; // База данных
$email_from = ""; // Емаил отправителя
$email_subject = "MySQL Backup file created"; // Тема сообщения
$email_txt = ""; // Текст сообщения
$email_to = ""; // Адрес получателя
//Путь к папке сохранения
$path = "/home/$user/public_html/backup"
#---Следующие параметры не менять---#
$date = date("d-m-Y_G:i");
$file = $db."_".$date.".sql.gz";
exec("mysqldump -u$user -p$pwd --databases $db | gzip > $path/$file");
$fileatt = "$path/$file";
$fileatt_type = "application/octet-stream";
$fileatt_name = "$file";
$headers = "From: ".$email_from;
$file = fopen($fileatt,'rb');
$data = fread($file,filesize($fileatt));
fclose($file);
$semi_rand = md5(time());
$mime_boundary = "==Multipart_Boundary_x{$semi_rand}x";
$headers .= "\nMIME-Version: 1.0\n" .
"Content-Type: multipart/mixed;\n" .
" boundary=\"{$mime_boundary}\"";
$email_message .= "This is a multi-part message in MIME format.\n\n" .
"--{$mime_boundary}\n" .
"Content-Type:text/html; charset=\"iso-8859-1\"\n" .
"Content-Transfer-Encoding: 7bit\n\n" .
$email_message . "\n\n";
$data = chunk_split(base64_encode($data));
$email_message .= "--{$mime_boundary}\n" .
"Content-Type: {$fileatt_type};\n" .
" name=\"{$fileatt_name}\"\n" .
//"Content-Disposition: attachment;\n" .
//" filename=\"{$fileatt_name}\"\n" .
"Content-Transfer-Encoding: base64\n\n" .
$data . "\n\n" .
"--{$mime_boundary}--\n";
mail($email_to, $email_subject, $email_message, $headers);
?>
PHP:
php -q /home/USERNAME/public_html/backup/mysql_backup.php