FoxWeb

софт для студентов
Искать здесь

Удалённое восстановление баз MySQL с помощью PHP

Раздел: PHP, MySQL, веб-программирование Автор: fox++
E-mail: спаму - нет! Www: http://foxweb.net.ru
Просмотров: 5959 Дата: 11.08.2005
Как импортировать большой SQL-скрипт (дамп базы данных MySQL для форума phpBB), если обычными споcобами (загрузка через web-интерфейс phpMyAdmin, Backup cPanel) проблематична, особенно на модемном соединении.

Проблема

Как импортировать большой SQL-скрипт (дамп базы данных MySQL для форума phpBB), если обычными споcобами (загрузка через web-интерфейс phpMyAdmin, Backup cPanel) проблематична, особенно на модемном соединении.

Решение

Можно попробовать через MySQL клиент типа SQLyog, MySQL-Front и т.д., но опять же не факт, что это закончится благополучно. Минимальное время - 1 (обычно 2-5) секунда на передачу и выполнение одной SQL-команды (а если их тысяч пять? загрузка займёт весь рабочий день, плюс нужно следить, не упала ли связь). Можно импортировать файл дампа с помощью phpMyAdmin или встроенных средств сPanel (что по сути один фиг), но закачивать большие объёмы данных методом POST из формы не очень надёжно и нецелесообразно - метод POST подходит для более рутинных задач, типа "Введите имя" и т.д.
 
Перепробовав все перечисленные способы, я выяснил, что основная проблема - непрерывная передача 9 Мб файла. Передать файл, говорите? Так это же делается через старый добрый FTP! Можно залить дамп на FTP (не волнуясь о целостности, ведь можно и докачать) и попросить админов восстановить базу, но не факт, что вам помогут, тем более на бесплатном хостинге. Хотя... где вы видели бесплатный хостинг с MySQL? Стыд и срам тому программисту, который каждый раз трясёт суппорт своими недоделками.
 
Пройдя через всё это, решил написать простенькую утилиту на PHP, которая будет читать SQL-файл построчно, точнее покомандно: выбирает команду (ограниченную точкой-с-запятой, исполняет её, и так далее по циклу). То есть все операции происходят внутри сервера, без участия клиента. Скорость бешеная, 9 Мб SQL-скрипт за 5 секунд!!! Ессесно, файлик должен лежать там же, где скрипт.

Минусы

Занимает большое количество ресурсов сервера, весь файл читается в память. Можно усовершенствовать, читая из файлового только отдельные SQL-команды. Будем считать это отправной точкой для сложной утилиты восстановления БД на сервере MySQL.

<?php
 
mysql_connect("localhost", "login", "password");
mysql_select_db ("database");
 
if (!file_exists($fname)) die ("Файл $fname не существует!");
$fp = fopen ($fname, "r");
$buffer = fread($fp, filesize($fname));
fclose ($fp);
 
$prev = 0;
 
while ($next = strpos($buffer,";",$prev+1))
{
$i++;
$a = substr($buffer,$prev+1,$next-$prev);
mysql_query($a);
$prev = $next;
}
 
echo "Выполнено $i команд";
 
?>

Что-то вроде этого.

$fname - имя файла SQL-дампа
$prev - позиция предыдущей ";"
$next - позиция следующей ";" начиная с позиции $prev
 
Вызываем скрипт примерно так: sqlbackup.php?fname=backup.sql, будет выполнен файл backup.sql. В конце выводится число выполненных команд. Я замеряю время выполнения для интереса, здесь для упрощения убрал. Каждый может усложнить, как считает нужным, это всего лишь простое решение повседневной задачи за пять минут.

Комментарии

Артём 29.08.2007 16:31:53 #
Скрипт понравился, но всеравно все сразу не смог закачать...
foxweb 30.08.2007 12:48:09 #
ЧИТАТЬ ВСЕМ!

На мой скрипт можно забить, рассматривайте его в образовательных целях, ковыряйте и т.д.

Для серьёзных вещей рекомендую использовать http://sypex.net/products/dumper/

При помощи него мне удалось обрабатывать 100 и более Мб данных.
nik 31.01.2008 19:17:19 #
А если одна таблица занимает 100м???
a_dick 25.03.2008 14:23:11 #
Скрипт лажа.
команды мускуля надо разбирать аналитически.
при использовании в значениях полей (INSERT,UPDATE)точки с запятой все дело к черту на кулички пойдет
klubben 04.04.2008 15:38:16 #
Во-первых, читать всесь файл в буфер есть бред, деволтный лимит 8М памяти на скрипт.

Во-вторых, как правильно заметил dick, считать разделителем комманд ; просто нельзя.

А самыйл полезный скрипт для поднятия дампов будет такой (с условием что у вас нет консольног доступа к серверу)


Будет работать у большенства хостеров
klubben 04.04.2008 15:42:05 #
Вот весь код:
<? `mysql $dbname -u $user --password=$pass < $path_to_dump` ?>

ЗЫ. Дебилу писавшему движок этого сайта оторвать яйца за неумение пользоваться функцией htmlspecialchars()

Оставить комментарий

Ваше имя

Ваш комментарий

Код   Защитный код. Если вы не видите здесь рисунок - обновите страницу.
Оценка   

Заметки по этой теме