Неверное отображение домена в ссылках

Описание проблемы

Ситуация: Вы установили CMS на свой домен в зоне .bget.ru, закончили разрабатывать сайт, купили домен в зоне .ru и прилинковали его к той же директории.

Например:

  • default.bget.ru - домен, на котором разрабатывался сайт;
  • normal.ru - домен, на который Вы хотите перенести сайт.

Оба домена прилинкованы к одному и тому же сайту /home/u/user/public_html

Открываем домен (normal.ru), сайт открывается, но все ссылки на сайте ведут на домен default.bget.ru

Решение

ВАЖНО! Перед этими действиями сделайте бекап файлов и базы данных! Сделать это можно в разделе BackUp. Все действия, описанные ниже, производятся при подключении по SSH. Если у Вас Windows, то воспользуйтесь программой PuTTy.

Заходим в директорию сайта:

$ cd /home/u/user/public_html

Далее находим все вхождения домена default.bget.ru в файлах:

$ grep -rl default.bget.ru .

В результате выполнения команды мы получим список файлов, пример ниже:

./templates/Default/main.tpl
./05f012a91b581da7242b4a85a0d088b2/words.db
./engine/cache/system/banners.php
./engine/cache/tagscloud_7a1920d61156abc05a60135aefe8bc67.tmp
./engine/data/config.php
./engine/modules/mymod.php

Далее выполняем команду замены вхождения одной строки на другую:

$ sed -e "s/default\.bget\.ru/normal\.ru/g" -i ./templates/Default/main.tpl
./05f012a91b581da7242b4a85a0d088b2/words.db и т.д.

Также можно выполнить процедуру в одну строку, если список файлов не слишком длинный:

$ grep -rl default.bget.ru . | xargs sed -e "s/default\.bget\.ru/normal\.ru/g" -i

или так:

$ grep -rl default.bget.ru . | while read line; do sed -e "s/default\.bget\.ru/normal\.ru/g" -i 
$line; done

После этого необходимо заменить все вхождения домена в базе данных. Узнать, какая база данных используется, можно из конфигурационного файла сайта. После того, как мы узнали имя базы данных, имя пользователя базы данных и пароль, делаем резервную копию базы данных (дамп), меняем в ней значения старого домена на новый и загружаем исправленный дамп обратно в базу.

$ mysqldump -u USER -pPASSWD USER | sed -e "s/default\.bget\.ru/normal\.ru/g" > dump.sql
$ mysql -u USER -pPASSWD USER < dump.sql
$ rm dump.sql


USER - это имя базы данных (оно же имя пользователя базы данных, например: login_db);
PASSWD - пароль к базе данных, который Вы установили. Заметьте, что между ключом -p и паролем пробел отсутствует.

Проверяем. Всё должно работать корректно. Если проблем не обнаружено, то архив, сделанный в начале статьи, можно удалять.





Удачной работы! Если возникнут вопросы - напишите нам, пожалуйста, тикет из Панели управления аккаунта, раздел "Помощь и поддержка".