===== Настройка веб-сервера на базе стека LEMP в Ubuntu Server 14.04 LTS. Часть 9. Перенос с другого хостинга сайта phpBB =====
В этой части мы рассмотрим порядок переноса со старого хостинга на наш [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04|веб-сервер на стеке LEMP]] сайта на движке [[:phpbb|phpBB]]. Так как этот сайт потребует для своей работы базу данных [[:mysql|MySQL]], первым делом выполним восстановление данных в [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04:setup-mysql-for-wordpress-and-phpbb|ранее созданную]] пустую БД из файла дампа (*.sql) сделанного на старом хостинге.
\\
==== Восстановление базы данных MySQL =====
Произведём восстановление резервной копии (дамп БД в виде sql-файла) в существующую пустую БД командой вида:
mysql -u 'forum-usr' -p'MySQLdbForumPaSSw0rD' 'forum-db' < ~/forumdb.sql
Как наверное понятно, мы выполняем восстановление базы данных не от имени mysql-пользователя **root**, а от имени mysql-пользователя, которому мы ранее дали права к этой БД, так как его прав для этой операции вполне достаточно.
\\
==== Настройка виртуального хоста Nginx ====
Прежде чем, копировать со старого хостинга файлы сайта **phpBB**, выполним настроку виртального хоста **nginx** таким образом, чтобы сузить права доступа к некоторым файлам, специфичным для **phpBB**:
sudo nano /etc/nginx/sites-available/forum.mydomain.ru
Какиой бы не была сделана конфигурация виртуального хоста, необходимо позаботиться о закрытии прямого доступа с помощью параметров в секциях **location {}** к каталогам **cache/**, **files/**, **store/** и файлам **.htaccess**, **config.php**
Пример конфигурационного файла виртуального хоста **nginx** можно найти в каталоге с файлами **phpBB** - **docs/nginx.sample.conf**
Приведу пример настроенного конфигурационного файла виртуального хоста для сайта форума **phpBB3** по условиям [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04|нашего цикла инструкций]]:
server {
listen 80;
server_name forum.mydomain.ru;
root /var/www/html/forum;
index index.php index.html index.htm;
access_log /var/log/nginx/access.forum.mydomain.ru.log;
error_log /var/log/nginx/error.forum.mydomain.ru.log;
location ~ /(config\.php|common\.php|cache|files|images/avatars/upload|includes|store) {
deny all;
return 403;
}
location ~ /\.svn|/\.git|/\.ht {
deny all;
}
location ~* \.(gif|jpe?g|png|css)$ {
expires 30d;
}
location / {
if (!-e $request_filename) {
rewrite ^(.*)$ /app.php;
}
}
location ~ \.php$ {
try_files $uri $uri/ /app.php?$query_string;
fastcgi_pass unix:/var/run/php5-fpm-forum.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
После изменения конфигурации виртуального хоста перезапустим **nginx**:
sudo service nginx restart
\\
==== Копирование файлов phpBB на веб-сервер ====
C помощью утилиты **scp** копируем со старого хостинга каталог с архивом сайта **phpBB** в домашний каталог текущего пользователя на нашем веб-сервере.
Затем копируем архив в [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04:setup-nginx-global-params-and-virtual-hosts-for-php-fpm|ранее поготовленную]] корневую папку виртуального хоста **nginx**, переходим в этот каталог и выполняем распаковку архива с последующим его обязательным удалением.
sudo cp ~/forum-backup.tgz /var/www/html/forum/
cd /var/www/html/forum/
tar xzf forum-backup.tgz
sudo rm forum-backup.tgz
\\
==== Настройка прав доступа к файлам phpBB ====
Теперь нам необходимо настроить разрешения на доступ к файлам **phpBB** на уровне файловой системы.
Установим рекурсивно в качестве владельца для всех файлов и каталогов сайта **phpBB** пользователя, от имени которого работает пул **php-fpm**, обслуживающий виртуальный хост сайта (этого пользователя и соответсвующую ему групп мы [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04:setup-php5-and-php-fpm-for-nginx|задали ранее]]):
sudo find /var/www/html/forum/ -exec sudo chown -R www-pool-forum {} \;
Такая конструкция изменения атрибутов файлов используется не просто.
Она позволяет установить нужные атрибуты на все файлы, в том числе и скрытые, типа **.htaccess**
За счёт вызова **sudo** для каждого файла/каталога выполнение команды может занять продолжительное время.
По аналогии назначим для всех файлов основную группу пользователя, от имени которого работает пул **php-fpm**:
sudo find /var/www/html/forum/ -exec sudo chgrp -R www-pool-forum {} \;
Рекурсивно установим права на все файлы и каталоги сайта c правом для записи только для владельца (пользователя, от имени которого работает пул **php-fpm**):
sudo find /var/www/html/forum/ -type d -exec sudo chmod 0755 {} \;
sudo find /var/www/html/forum/ -type f -exec sudo chmod 0644 {} \;
В некоторых источниках можно встретить рекомендацию установки расширенных прав на некоторые каталоги **phpBB**, примерно таким образом:
cd /var/www/html/forum/
sudo chmod 777 store/ cache/ files/ images/avatars/upload
Однако практика использования описанной в [[:unix-linux:ubuntu:ubuntu-14-04-lts-trusty-tahr:how-to-install-lemp-web-server-on-ubuntu-14-04|цикле инструкций]] конфигурации показывает,
что такие права для штатной работы форума не нужны.
\\
==== Подключение скриптов phpBB к БД MySQL ====
Следующим действием будет настройка одного из конфигурационных скриптов **phpBB** (**config.php**) для возможности подключения к ранее восстановленной базе данных [[:mysql|MySQL]]:
sudo nano /var/www/html/forum/config.php
Изменим в файле значения указанных ниже переменных:
$dbms = 'mysql';
$dbhost = 'localhost';
$dbport = '';
$dbname = 'forum-db';
$dbuser = 'forum-usr';
$dbpasswd = 'MySQLdbForumPaSSw0rD';
Сохраняем изменения в файле и проверяем работу сайта через веб-браузер.
Если всё сделано правильно, но возникают ошибки исполнения php-скриптов, из которых понятно, что некоторые скрипты пытаются получить доступ к БД MySQL с параметрами старого хостинга, то возможно нам ещё потребуется выполнить [[:phpbb:forced-cleaning-purging-the-phpbb-cache-manually|форсированную очистку кэша phpBB]]
\\
==== Дополнительные источники информации ====
* [[https://www.phpbb.com/community/docs/INSTALL.html|phpBB.com - phpBB 3.1.x Install]]
* [[https://www.phpbb.com/support/docs/en/3.0/kb/article/phpbb3-chmod-permissions/|phpBB.com - phpBB3 Chmod Permissions]]
* [[http://nginxlibrary.com/phpbb-configuration/|Nginx Library - Nginx configuration for phpBB]]
----
{{:user:blogroot.png?50&nolink |}} Автор первичной редакции:\\ [[user:blogroot|Алексей Максимов]] \\ Время публикации: 29.03.2016 19:00
{{tag>Linux Ubuntu "Ubuntu 14.04" "14.04 LTS" "Ubuntu Server" "web server" LEMP MySQL Nginx "virtual host" vhost PHP PHP-FPM phpBB phpBB3}}
~~DISCUSSION~~