WordPress — перенос на другой домен
10.06.2013
Сегодня столкнулся с задачей — перенести готовый сайт (вот этот, который Вы сейчас читаете) на WordPress с «development» домена в «production» домен.
Задача на первый взгляд банальная, и я не ожидал что возникнут трудности — но, оказалось что в случае с WordPress, это не так просто как кажется.
В интернете достаточно много советов которые сводятся к «найди и замени», но это подойдёт к «простым» проектам. В случае если у Вас WordPress напичкан виджетами, шоткодами и т.п. «найди и замени» не достаточно т.к. большинство из них хранит данные в JSON формате в базе данных. Полазив в просторах интернета я так и не нашёл готового решения для таких случаев, но нашёл «почти готовое» на сайте http://davidcoveney.com/ — собрав там всё в кучу, предлагаю вашему вниманию.
Исходим из того что Ваш старый домен «oldsite.com», а новый «newsite.com»:
Экспортируем базу данных в файл:
- заходим в phpMyAdmin и в левой части выбираем нашу базу данных
- нажимаем кнопку экспорт в правой верхней части экрана
- выбираем способ экспорта «Обычный — отображать все возможные настройки» и выбираем все таблицы нажав «Выделить все»
- по умолчанию имя базы данных будет использоваться имя файл экспорта. Вы можете изменить это, введя нужное имя файла в поле Имя файла. Вы также можете выбрать опцию сжатия (например, «сжатый»)
- убедитесь, что в Параметрах включено «структура и данные». в «Параметры создания объектов» включите «Добавить выражение DROP TABLE / VIEW / PROCEDURE / FUNCTION / EVENT».
- нажимайте кнопку «Go» и сохраняйте файл экспорта на диск своего компьютера.
Импортируем базу данных из файла:
- если база данных, в которую Вы собираетесь импортировать данные, ещё не создана — создайте её.
- в левой части выбираем нашу базу данных
- нажимаем кнопку импорт в правой верхней части экрана
- выбираем файл импорта нажав кнопку «Обзор»
- нажимаем кнопку «Go» и ждём завершения импорта данных из файла
Переносим файлы
Даже растерялся как описать процесс переноса файлов — множество ftp менеджеров, различные условия на хостингах. Действие по сути простое: со старого хостинга (домена) берём все файлы и папки корневой веб директории и копируем на локальный компьютер; с локального компьютера опять же один в один копируем их в корневую веб директорию нового хостинга (домена).
Если у кого-то с этим возникнут проблемы — можете спросить здесь же в комментариях.
Изменяем конфигурацию
- файл wp-config.php — изменяем параметры доступа к базе данных
- скачиваем этот архив содержащий php скрипт migrate.php себе на компьютер, распаковываем.
- изменяем файл migrate.php
- загружаем его в корневую веб директорию и запускаем открыв урл http://newsite.com/migrate.php
/** Имя базы данных для WordPress */
define('DB_NAME', 'new_db');
/** Имя пользователя MySQL */
define('DB_USER', 'new_user');
/** Пароль к базе данных MySQL */
define('DB_PASSWORD', 'new_password');
Подготавливаем и запускаем скрипт migrate.php
$search_for = 'oldsite.com'; // старый домен
$replace_with = 'newsite.com'; // новый домен
Этот скрипт проведёт замену по всей базе данных, так же он проведёт корректировку JSON данных.
Вот в общем-то и всё. Отличие этой инструкции от тысяч других в интернете — это как раз скрипт migrate.php, который позволит Вам корректно заменить все данные в базе (включая JSON).
Есть вопросы или возникли проблемы с переносом WordPress — спрашивайте, постараюсь ответить.