Linux mint nginx php mysql

Содержание
  1. linux. Установить nginx + php7.2 + mysql
  2. Инструкции
  3. Командная строка Linux: краткий курс для начинающих
  4. Перенаправление ввода/вывода в Linux
  5. Работа с файлами и каталогами в Linux
  6. Как сгенерировать SSH-ключ для доступа на сервер
  7. Как установить и настроить веб-сервер Apache
  8. Руководство по написанию скриптов в Linux Bash
  9. Введение в Git: настройка и основные команды
  10. Как установить MySQL на Windows
  11. Как установить и использовать MySQL Workbench
  12. Создание нового пользователя и настройка прав в MySQL
  13. Как установить Linux, Nginx, MySQL, PHP (LEMP) в Ubuntu 18.04/20.04
  14. Сравнение серверов Apache и Nginx
  15. 1 этап. Подготовка сервера
  16. Создание пользователя
  17. Обновление операционной системы
  18. 2 этап. Установка Nginx
  19. Настройка Nginx
  20. 3 этап. Установка MySQL
  21. Настройка безопасности MySQL
  22. Работа с базой данных
  23. Как создать пользователя
  24. Как создать базу данных
  25. 4 этап. Установка PHP Ubuntu
  26. Настройка PHP Ubuntu
  27. Как установить Linux, Nginx, MySQL, PHP (LEMP) в Ubuntu 16.04
  28. Введение
  29. Перед установкой
  30. Шаг 1 — Установка веб-сервера Nginx
  31. Шаг 2 — Установка MySQL для хранения данных сайта
  32. Шаг 3 — Установка PHP
  33. Настройка обработчика PHP
  34. Шаг 4 — Настройка Nginx для работы с обработчиком PHP
  35. Шаг 5 — Создание файла PHP для проверки настроек
  36. Заключение

linux. Установить nginx + php7.2 + mysql

Установка связки nginx, php7.2, и mysql server на Linux Ubuntu 16.04 и Linux Ubuntu 18.04

Для начала, необходимо запустить терминал (ctrl + alt + t) обновить Ubuntu и пакеты:

И начнем с установки NGINX.
Для этого в терминале пишем:

Приступаем к установке php7.2-fpm
В Ubuntu 18.04 достаточно в терминале запустить команду установки:

В Ubuntu 16.04 необходимо для начала добавить репозитарий и только после этого приступить к установке:
В первую очередь скачиваем и устанавливаем пакет python-software-properties для добавления нового репозитария.

И обновляем пакеты:

После обновления приступаем к установке:

После того, как php-fpm будет установлен, переходим к установке mysql server.
Для установки MySql достаточно выполнить команду:

После того как все будет установлено, необходимо выполнить настройку NGINX и PHP-FPM.
Настраиваем nginx.
Открываем файл с настройками для локального хоста:

Находим конфигурацию server и меняем на:

Настраиваем php-fpm.
Открываем файл с настройками PHP-FPM:

Проверяем на наличие данной строки (Если ее нет, то добавляем):

После проведения всех манипуляций перезагружаем php-fpm и nginx (лучше перезапустить PC для перезагрузки всех сервисов):

Для проверки на работоспособность создадим PHP файл:

И пропишем в нем:

Сохраняем ctrl + o и выходим из редактирования ctrl + x.

После чего открываем браузер и переходим по ссылке:

Вы должны увидеть страницу с информацией о текущей версии PHP примерно следующего содержания:

Источник

Инструкции

27 сентября 2021

Командная строка Linux: краткий курс для начинающих

27 сентября 2021

Перенаправление ввода/вывода в Linux

27 сентября 2021

Работа с файлами и каталогами в Linux

26 сентября 2021

Как сгенерировать SSH-ключ для доступа на сервер

23 сентября 2021

Как установить и настроить веб-сервер Apache

23 сентября 2021

Руководство по написанию скриптов в Linux Bash

21 сентября 2021

Введение в Git: настройка и основные команды

21 сентября 2021

Как установить MySQL на Windows

21 сентября 2021

Как установить и использовать MySQL Workbench

20 сентября 2021

Создание нового пользователя и настройка прав в MySQL

© ООО «Селектел», 2008—2021

Полностью изолированные физические серверы любой конфигурации с облачной готовностью

Виртуальные машины с моментальным масштабированием и поддержкой Infrastructure-as-code

В дата-центрах TIER III Москвы, Санкт‑Петербурга и ЛО

Инфраструктура на базе VMware для бизнес-критичных задач любой сложности

Готовые к работе управляемые базы данных PostgreSQL и MySQL™

Полностью готовый к работе кластер Kubernetes для управления контейнерами

Масштабируемое хранилище данных с гибким ценообразованием, поддержкой FTP и S3 API

Запуск кода по запросу или событию без создания и обслуживания сервера

Источник

Как установить Linux, Nginx, MySQL, PHP (LEMP) в Ubuntu 18.04/20.04

LEMP — стек технологий, используемый для развертывания веб-приложений. В отличии от LAMP, в LEMP вместо Apache устанавливается Nginx.

В REG.RU вы можете заказать облачный сервер с установленным шаблоном LEMP на базе операционной системы Ubuntu 20.04. В данной статье описана ручная установка LEMP на Ubuntu 18.04/20.04.

Сравнение серверов Apache и Nginx

  • Разрабатывается с 1995 года, огромное количество пользователей, многочисленные модули, предназначенные для расширения его функциональности.
  • Медленная работа веб-сервера из-за поточно-ориентированного подхода при большой нагрузке. Необходимость создавать новые процессы и увеличивать объём потребляемой памяти.
  • Необходимость устанавливать ограничения по потребляемым ресурсам. При достижении ограничений новые соединения будут отклонены.
  • Веб-сервер с открытым исходным кодом, написанный как аналог Apache для решения проблем с производительностью и масштабируемостью.
  • Механизм, управляемый событиями, асинхронный и неблокирующий, не создаёт новые процессы для каждого веб-запроса.
Читайте также:  Windows checking dns server

1 этап. Подготовка сервера

Все действия по установке производятся на сервере через подключение по SSH.

Создание пользователя

Все действия по установке LEMP рекомендуем выполнять не через пользователя root. Рекомендуем создать пользователя с sudo-правами. Так вы дополнительно обезопасите свой сервис и избежите случайных ошибок, которые могут сломать вашу операционную систему.

Чтобы создать пользователя, введите команду:

Где UserName — имя нового пользователя.

Система попросит ввести пароль для нового пользователя и дополнительную информацию:

Теперь установите права доступа, чтобы новый пользователь мог использовать команду sudo. Для этого выполните команду:

Где UserName — имя созданного ранее пользователя.

Готово. Новый пользователь создан. Завершите SSH-сеанс под root и подключитесь к серверу под новым пользователем. Или введите команду:

Обновление операционной системы

Прежде чем установить на Ubuntu LEMP, нужно обновить операционную систему до актуального состояния с помощью команды:

2 этап. Установка Nginx

Для установки Nginx введите команду:

На этом установка закончена. В Ubuntu Nginx настроен на запуск сразу после установки.

Настройка Nginx

Для корректной работы Nginx необходимо настроить firewall, открыть порты для подключения к серверу.

Чтобы открыть доступ для подключения к серверу по HTTP, выполните команды:

Если вы планируете использовать SSL-сертификат, для подключения по HTTPS выполните команду:

При переходе по IP-адресу вашего сервера откроется страница Nginx:

Готово. Установка Nginx завершена.

3 этап. Установка MySQL

Далее нам необходимо установить систему управления базами данных MySQL.

В зависимости от версии MySQL во время установки вам будет предложено ввести пароль root-пользователя (пароль администратора) сервера баз данных:

Если это окно не появилось, значит настройка MySQL для вашей версии выполняется без пароля. Аутентификация для пользователя root в этом случае происходит при помощи плагина auth_socket. Чтобы проверить способ аутентификации:

На экране вы увидите:

Настройка безопасности MySQL

После того как вы смогли установить MySQL в Ubuntu, выполните скрипт безопасности. Для этого следуйте инструкции:

Запустите скрипт командой:

Введите «Y» и нажмите Enter:

Вам нужно задать допустимую сложность пароля от 0 до 2 при помощи плагина VALIDATE PASSWORD, где:

0 — слабый пароль из 8 и более символов. Использование цифр и специальных символов не обязательно;

1 — средний пароль из 8 и более символов. Обязательно использование цифр и специальных символов;

2 — сложный пароль из 8 и более символов. Обязательное использование цифр и специальных символов и запрет на использование общих фраз.

Для этого введите нужную цифру и нажмите Enter. Затем задайте и подтвердите пароль. В будущем плагин не позволит использовать пароли, которые не соответствуют уровню, который вы выбрали.

На каждом следующем этапе вам нужно ввести «Y» и нажать Enter. Таким образом вы:

удалите анонимных пользователей,

запретите удалённое подключение для root-пользователя,

удалите тестовую базу данных,

перезагрузите таблицу привилегий.

Готово, первоначальная настройка безопасности MySQL выполнена.

Работа с базой данных

Для работы с базой данных вам необходимо создать пользователя и саму базу.

После установки MySQL автоматически будет создан root-пользователь. Работать с базой данных под root небезопасно, поэтому необходимо создать нового пользователя и назначить ему права доступа.

Запустите сервер базы данных с помощью команды:

Система запросит пароль, который был указан при установке MySQL.

Как создать пользователя

Создайте пользователя с помощью команды:

Замените значения внутри кавычек:

  • вместо user-name укажите логин пользователя базы данных;
  • вместо password укажите пароль нового пользователя.

Назначьте все права доступа для созданного пользователя:

Не забудьте изменить user-name на логин, который был указан при создании пользователя.

Чтобы изменения вступили в силу, введите команду:

Как создать базу данных

Для создания базы данных введите команду:

Где BaseName — это название базы данных.

Готово. Теперь вы можете удалённо подключиться к базе данных или привязать её к вашему проекту. Чтобы завершить работу с MySQL, нажмите Ctrl + D.

4 этап. Установка PHP Ubuntu

Для установки PHP введите команду:

Настройка PHP Ubuntu

Теперь настройте безопасность интерпретатора, чтобы избежать запуск нежелательных файлов. Для этого откройте файл конфигурации командой:

Если ни одна из команд не подходит, узнайте версию PHP на вашем сервере командой:

Затем выполните команду:

Вместо X.X подставьте версию PHP на вашем сервере.

Найдите в файле параметр cgi.fix_pathinfo , раскомментируйте его, убрав точку с запятой перед ним, и установите значение «0». В редакторе nano вы можете воспользоваться поиском по файлу клавишей F6.

По умолчанию, если запрашиваемый PHP файл будет не найден, то интерпретатор попытается исполнить ближайший файл, который сможет найти. Данная настройка позволит ограничить доступ к файлам.

Сохраните изменения в файле и закройте его:

Источник

Как установить Linux, Nginx, MySQL, PHP (LEMP) в Ubuntu 16.04

Published on March 7, 2017

Читайте также:  What is page cache linux

Введение

Стек LEMP представляет собой набор программного обеспечения, который используется для отображения динамических веб-страниц и веб-приложений. Этот акроним обозначает операционную систему Linux и веб-сервер Nginx. Данные при этом хранятся в базе данных MySQL, а динамическое отображение страниц выполняется средствами PHP.

В этой статье мы продемонстрируем процесс установки стека LEMP на сервер с Ubuntu 16.04. Операционная система Ubuntu удовлетворяет первому требованию LEMP — это операционная система на базе Linux. Далее мы опишем процесс установки остальных компонентов стека LEMP.

Перед установкой

Перед тем, как начать следовать описанным в этой статье шагам, убедитесь, что у вас есть обычный не-рутовый (non-root) пользователь с привилегиями sudo . Узнать, как настроить такого пользователя на вашем сервере, можно из статьи о первичной настройке сервера на Ubuntu 16.04.

После того, как вы создали такого пользователя, зайдите на сервер используя его логин и пароль. Теперь вы готовы следовать шагам, описанным в этой статье.

Шаг 1 — Установка веб-сервера Nginx

Для отображения веб-страниц вашего сайта мы будем использовать Nginx — современный и эффективный веб-сервер.

Всё программное обеспечение, которое мы будем использовать, будет установлено из стандартных репозиториев Ubuntu. Это означает, что мы можем использовать пакетный менеджер apt для установки.

Поскольку мы собираемся использовать apt в первый раз в ходе этой сессии, начнём с обновления локального списка пакетов. Далее установим сервер:

В Ubuntu 16.04 Nginx настроен для запуска сразу после установки.

Если вы используете файрвол ufw , как описано в нашей статье о первичной настройке сервера, вам потребуется разрешить соединения для Nginx. В процессе установки Nginx регистрирует себя в ufw , поэтому процедура настройки достаточно проста.

Рекомендуется настраивать ufw таким образом, чтобы разрешать только тот трафик, который вы хотите разрешить в явном виде. Поскольку мы ещё не настроили SSL для нашего сервера, в этой статье мы разрешим трафик только для порта 80.

Сделать это можно следующей командой:

Вы можете проверить изменения введя команду:

В результате должен отобразиться вывод следующего вида:

Теперь, когда мы разрешили трафик на порту 80, вы можете проверить, можно ли осуществить доступ к вашему серверу используя доменное имя или публичный IP адрес сервера в веб-браузере.

Если у вас нет доменного имени, присвоенного серверу, и вы не знаете публичного IP адреса сервера, вы можете найти этот IP адрес следующей командой:

В результате будет выведено несколько IP адресов. Попробуйте вставить каждый из них в браузер.

Другим способом определить свой IP адрес будет проверка, как ваш сервер виден из Интернета:

Наберите полученный IP адрес в вашем веб-браузере. Вы должны увидеть страницу Nginx по умолчанию.

Если вы видите подобную страницу в своём браузере, вы успешно установили Nginx.

Шаг 2 — Установка MySQL для хранения данных сайта

Теперь, когда у нас есть веб-сервер, установим систему управления базами данных MySQL для хранения и управления данным нашего сайта.

Вы можете легко установить MySQL следующей командой:

В процессе установки вам будет предложено ввести рутовый пароль (пароль администратора) для MySQL.

После завершения установки нам потребуется выполнить некоторые дополнительные команды, чтобы наше окружение MySQL было настроено безопасным образом. Введите следующую команду:

Скрипт запросит пароль, который вы только что задали для root пользователя в MySQL. Далее вам будет предложено сконфигурировать плагин валидации паролей ( VALIDATE PASSWORD PLUGIN ).

Внимание: решение включать плагин валидации паролей или нет носит субъективный характер. При включении все пароли, которые не удовлетворяют определённым критериям безопасности, будут отвергаться MySQL с сообщением об ошибке. Это может вызывать проблемы, если вы используете “слабые” пароли совместно с программным обеспечением, которое конфигурирует профили пользователей MySQL, например, пакеты Ubuntu для phpMyAdmin. Вы можете оставить валидацию паролей отключенной, но в этом случае вам следует всегда использовать “сильные” уникальные пароли для пользователей базы данных.

Введите y для включения плагина или что-нибудь другое для продолжения без его включения:

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

Если вы включили валидацию паролей, вам будет показан уровень надёжности заданного вами ранее пароля root пользователя, а также вам будет предложено изменить этот пароль. Если вы не хотите менять пароль, введите n или no:

Читайте также:  Zabbix system run windows

На все последующие вопросы просто вводите Y и нажимайте клавишу ENTER для выбора настроек по умолчанию. При этом удалятся некоторые тестовые пользователи и базы данных, будет отключена возможность удаленного доступа с учетной записью root-пользователя, и все изменения будут немедленно применены в MySQL.

Теперь ваша система управления базами данных установлена и мы можем двигаться дальше.

Шаг 3 — Установка PHP

Теперь у нас есть веб-сервер Nginx для отображения нашего сайта, а также MySQL для хранения данных сайта. Нам осталось установить что-то, что позволит генерировать динамический контент для сайта. Для этого мы будем использовать PHP.

Поскольку Nginx не имеет встроенной поддержки обработки PHP, как некоторые другие веб-серверы, нам необходимо установить php-fpm (означает “fastCGI process manager”, менеджер процессов fastCGI). Мы настроим Nginx для передачи PHP запросов этому программному обеспечению для обработки.

Установим этот модуль, а также установим дополнительный пакет, который позволит PHP взаимодействовать с MySQL. В процессе установки будут загружены основные файлы PHP. Сделаем это следующей командой:

Настройка обработчика PHP

После установки компонентов PHP настроим их для повышения безопасности нашего веб-сервера.

Откроем конфигурационный файл php-fpm с привилегиями root:

Найдём в этом файле параметр cgi.fix_pathinfo . Он будет закомментирован точкой с запятой (;) и будет иметь значение “1” по умолчанию.

Эти настройки по умолчанию очень небезопасны, потому что благодаря им PHP попытается исполнить ближайший файл, который сможет найти в случае, когда запрашиваемый PHP файл не может быть найден. Это позволит пользователям сформировать PHP запросы таким образом, чтобы запускать скрипты, к которым у них не должно быть доступа.

Мы можем предотвратить такое поведение раскомментировав эту строку и изменив её значение на “0”:

Сохраните и закройте документ после внесения изменений.

Теперь нам осталось перезапустить обработчик PHP:

После перезапуска наши настройки вступят в силу.

Шаг 4 — Настройка Nginx для работы с обработчиком PHP

Теперь у нас установлены все необходимые компоненты. Единственное, что нам осталось сделать, это настроить Nginx для использования нашего обработчика PHP для отображения динамического контента.

Мы сделаем это на уровне серверных блоков (серверные блоки являются приблизительным аналогом виртуальных хостов в Apache). Откроем серверный блок Nginx сервера по умолчанию командой:

Этот файл должен иметь примерно следующий вид:

Нам необходимо внести несколько изменений в этот файл для нашего сайта.

  • Прежде всего, нам необходимо добавить index.php первым значением директивы index , чтобы веб-сервер в первую очередь искал файлы index.php .
  • Мы можем изменить директиву server_name для указания доменного имени сервера или его публичного IP адреса.
  • Для корректной обработки PHP нам необходимо раскомментировать часть файла, которая отвечает за обработку PHP запросов. Это блок location

\.php$ , кусок кода fastcgi-php.conf и сокет для работы с php-fpm .

  • Мы также раскомментируем код, отвечающий за работу с файлами .htaccess . Nginx не обрабатывает эти файлы. Если какие-то из этих файлов окажутся в корневой директории сайта, они не должны быть доступны пользователям.
  • Изменения, которые необходимо внести в этот файл помечены красным:

    После внесения изменений сохраните и закройте файл.

    Проверьте ваш файл конфигурации на наличие ошибок командой:

    Если в результате обнаружены какие-либо ошибки, откройте файл и исправьте их перед тем, как продолжить.

    Когда всё готово, перезапустите Nginx для применения внесённых изменений:

    Шаг 5 — Создание файла PHP для проверки настроек

    Теперь ваш стек LEMP должен быть полностью готов к работе. Мы можем проверить, что Nginx корректно передаёт .php файлы нашему обработчику PHP.

    Для этого создадим тестовый PHP файл в корневой директории веб-сервера. Откройте файл с именем info.php в корневой директории веб-сервера с помощью текстового редактора:

    Наберите или введите следующие строки в этот новый файл. Этот код PHP возвращает информацию о нашем сервере:

    После внесения изменений сохраните и закройте файл.

    Теперь мы можем проверить, может ли веб-сервер корректно отображать контент, сгенерированный PHP скриптом. Для проверки нам просто нужно открыть данную страницу в веб-браузере. Вам снова потребуется публичный IP-адрес сервера.

    Откроем этот адрес:

    Страница, на которую вы попадёте, должна выглядеть похожим образом:

    Если вы видите эту страницу, вы успешно настроили обработку PHP с помощью Nginx.

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

    Удалим файл командой:

    Заключение

    Теперь у вас есть полностью настроенный стек LEMP на вашем сервере Ubuntu 16.04. Этот стек представляет собой прочный фундамент дальнейшей работы по предоставлению вашим пользователям веб-контента.

    Источник

    Оцените статью