Установка nginx + php fpm + mysql + memcache на UBUNTU 18.04: различия между версиями
Misha (обсуждение | вклад) (→Настройка NGINX для работы с PHP fpm сервером.) |
Misha (обсуждение | вклад) (→Настройка NGINX для работы с PHP fpm сервером.) |
||
Строка 76: | Строка 76: | ||
deny all; | deny all; | ||
}</pre> | }</pre> | ||
− | |||
После сделанных изменений, сохраняем и закрываем файл.<br> | После сделанных изменений, сохраняем и закрываем файл.<br> | ||
Проверяем конфигурацию nginx | Проверяем конфигурацию nginx | ||
Строка 82: | Строка 81: | ||
И если ошибок нет, то перезапускам nginx. | И если ошибок нет, то перезапускам nginx. | ||
<pre>sudo systemctl reload nginx</pre> | <pre>sudo systemctl reload nginx</pre> | ||
+ | ==Создание файла для проверки конфигурации== | ||
+ | Для проверки можно создать файл с любым кодом PHP и проверить как оно работает.<br> | ||
+ | Например, создаем файл /var/www/html/index.php со следующим содержимым | ||
+ | <pre><?php | ||
+ | phpinfo();</pre> | ||
+ | Теперь в браузере заходим http://server_domain_or_IP/index.php<br> | ||
+ | И если Вы увидите таблицу настроек PHP, то настройки сделаны правильно. |
Версия 16:53, 27 июня 2018
Содержание
Источники информации
- How To Install Linux, Nginx, MySQL, PHP (LEMP stack) in Ubuntu 16.04.
- Install Nginx with PHP-FPM and Memcached Support on Ubuntu 17.04 / 17.10.
Обновление системы
Для начала обновляем систему
$ sudo apt update $ sudo apt upgrade
Установка NGINX
sudo apt install nginx
После инсталляции NGINX будет стартовать автоматически после перезагрузки.
Если у Вас установлен фаервол ufw, то его настройка описана в [статье. Здесь описывать не буду.
Находим ip адрес компьютера
ifconfig
и пробуем зайти на него из браузера по адресу http://<local_address_server>
Если получили приглашение NGINX - идем дальше.
Установка MYSQL сервера
$ sudo apt install mysql
В данной версии вход пользователем mysql/root сделан только от системного пользователя root и без пароля, поэтому mysql_secure_installation запускаем так.
$ sudo mysql_secure_installation
И выполняем все, что предлагает скрипт
Примечание: У меня не получилось изменить пароль mysql/root и вход так и остался, через sudo mysql -uroot - без пароля.
Установка и настройка PHP
Установка
$ sudo apt-get install php-fpm php-mysql
Настройка
sudo nano /etc/php/7.2/fpm/php.ini
Было
;cgi.fix_pathinfo=1
Стало
cgi.fix_pathinfo=1
Заодно можно сделать настройки указанные тут
Теперь нам надо просто перезапустить PHP fpm сервис.
$ sudo systemctl restart php7.2-fpm
Настройка NGINX для работы с PHP fpm сервером.
Мы установили все нужные компоненты. Осталось только сделать настройки Nginx, что бы он работал с динамическим контентом через PHP сервер.<php> Открываем настройки Nginx сервера по умолчанию:
sudo nano /etc/nginx/sites-available/default
Файл /etc/nginx/sites-available/default выглядит примерно так
server { listen 80 default_server; listen [::]:80 default_server; root /var/www/html; index index.html index.htm index.nginx-debian.html; server_name _; location / { try_files $uri $uri/ =404; } }
Мы должны сделать некоторые изменения для нашего сайта
- Во-первых, нам нужно добавить index.php в качестве первого значения строки директивы index, так чтобы файл с именем index.php был открыт, если он доступен, когда запрашивается каталог.
- Мы можем изменить директиву server_name, чтобы указать доменное имя или общедоступный IP-адрес нашего сервера.
- Для фактической обработки PHP нам просто нужно раскомментировать сегмент файла, который обрабатывает запросы PHP, удаляя символы фунта (#) перед каждой строкой. Это будет блок местоположения ~ \ .php $, включенный фрагмент fastcgi-php.conf и сокет, связанный с php-fpm.
- Мы также раскомментируем блок местоположения, связанный с файлами .htaccess, используя тот же метод. Nginx не обрабатывает эти файлы. Если какой-либо из этих файлов попадает в корень документа, они не должны обслуживаться посетителями.
Было
index index.html index.htm index.nginx-debian.html;
Стало
index index.php index.html index.htm index.nginx-debian.html;
Было
server_name _;
Стало
server_name server_domain_or_IP;
И добавляем модули location в модуль server
location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/run/php/php7.2-fpm.sock; } location ~ /\.ht { deny all; }
После сделанных изменений, сохраняем и закрываем файл.
Проверяем конфигурацию nginx
sudo nginx -t
И если ошибок нет, то перезапускам nginx.
sudo systemctl reload nginx
Создание файла для проверки конфигурации
Для проверки можно создать файл с любым кодом PHP и проверить как оно работает.
Например, создаем файл /var/www/html/index.php со следующим содержимым
<?php phpinfo();
Теперь в браузере заходим http://server_domain_or_IP/index.php
И если Вы увидите таблицу настроек PHP, то настройки сделаны правильно.