Настройка LAMP в Debian 11 2024

Главная » Блог программиста » Настройка LAMP в Debian 11 2024

Просмотров: 204

Настройка LAMP в Debian 11 2024

Для установки LAMP на VDS регистрируемся на Firstbyte, выбираем подходящий тариф (например MSK-KVM-SSD), в качестве ОС выбираем Debian 11.
Примечание:

Символ # в начале строки означает, что команда должна быть запущена от пользователя root

Символ $ в начале строки означает, что команда должна быть запущена от Вашего созданного пользователя

Установку возможно производить через скрипт (пункты 0-9)

wget https://iproger.ru/content/uploads/lamp-debian11.sh
chmod +x lamp-debian11.sh
./lamp-debian11.sh

Установку можно произвести вручную по командам:
0) обновляем список пакетов

# apt update && apt upgrade

1) устанавливаем программы для более удобного управления сервером:

# apt -y install lsb-release apt-transport-https ca-certificates curl dirmngr gnupg2 mc nano

2) добавляем репозиторий с php 8.2:

Зеркала:
https://ftp.mpi-inf.mpg.de/mirrors/linux/mirror/deb.sury.org/repositories/php/apt.gpg
This is Octopuce's official and unofficial Debian package repository mirrors
https://debian.octopuce.fr/
https://debian.octopuce.fr/sury-php/
За надежность не ручаюсь:
http://dk.archive.ubuntu.com/deb.sury.org/php/
https://dk.mirror.archlinuxarm.org/deb.sury.org/php/

curl -sSLo /etc/apt/keyrings/sury.org-php.gpg https://ftp.mpi-inf.mpg.de/mirrors/linux/mirror/deb.sury.org/repositories/php/apt.gpg
sh -c 'echo "deb [signed-by=/etc/apt/keyrings/sury.org-php.gpg] https://ftp.mpi-inf.mpg.de/mirrors/linux/mirror/deb.sury.org/repositories/php/ $(lsb_release -sc) main" > /etc/apt/sources.list.d/php.list'
mkdir /etc/apt/keyrings
curl -sSLo /etc/apt/keyrings/sury.org-php.gpg https://ftp.mpi-inf.mpg.de/mirrors/linux/mirror/deb.sury.org/repositories/php/apt.gpg
apt update


3) устанавливаем apache+php:

# apt -y install apache2 apache2-dev php8.2 php8.2-gd php8.2-curl php8.2-cli php8.2-cgi php8.2-dev php8.2-zip php8.2-mbstring php8.2-xml php8.2-mysql

Для apache2 дополнительно:

apt -y install libapache2-mod-php8.2 php8.2-fpm
Добавляем в автозагрузку:
systemctl enable apache2

4) добавим поддержку кэширования (cache-control) и rewrite:

# a2enmod headers
a2enmod rewrite
a2enmod ssl

5) очищаем страницу-заглушку apache:

# echo "" > /var/www/html/index.html

6) далее устанавливаем пакет apache2-mpm-itk (для запуска виртуальных хостов от своего пользователя):

# apt -y install libapache2-mpm-itk

7) далее устанавливаем git:

# apt -y install git

8) Для поддержки SSL-сертификатов:

apt install letsencrypt
apt install python3-certbot-apache

9) Устанавливаем сервер MySQL (MariaDB):

# curl -LsS -O https://downloads.mariadb.com/MariaDB/mariadb_repo_setup
bash mariadb_repo_setup --os-type=debian  --os-version=bullseye --mariadb-server-version=11.5
apt -y install mariadb-server
mysql_secure_installation
systemctl enable mariadb

Для битрикса в файле /etc/mysql/mariadb.conf.d выставляем:

character-set-server  = utf8
collation-server      = utf8_unicode_ci


При необходимости открываем доступ с внешних ресурсов к базе данных.
10) Изменяем настройки:
10.1) Устанавливаем PMA (phpmyadmin), при необходимости:
apt -y install phpmyadmin

10.2) в файле /etc/apache2/apache2.conf добавить это:

ServerName localhost
Include /etc/phpmyadmin/apache.conf

10.3) линкуем phpmyadmin, если не открывается:

# ln -s /usr/share/phpmyadmin/ /var/www
ln -s /etc/apache2/sites-available/ /var/www
chmod -R 777 /etc/apache2/sites-available/000-default.conf
chmod -R 777 /var/lib/phpmyadmin/tmp

11) правим файл /etc/php/8.2/apache2/php.ini а также /etc/php/8.2/fpm/php.ini (для crontab)

max_execution_time = 120
max_input_time = 90
memory_limit = 128M
post_max_size = 150M
upload_max_filesize = 150M
session.gc_maxlifetime = 14400
short_open_tag = On
date.timezone = Europe/Moscow
; для битрикса:
max_input_vars = 10000
opcache.max_accelerated_files=100000
opcache.revalidate_freq=0

раскомментируем в этом же файле строчку:

extension=mysqli

12) создадим пользователя:

# useradd username
passwd username

12.1) Если нужно скрыть информацию о сервере на страницах 403,404 и пр. в файле

/etc/apache2/apache2.conf

 добавляем:

ServerTokens Prod
ServerSignature Off

Перезапускаем apache:

service apache2 restart

Устанавливаем npm:

curl -sL https://deb.nodesource.com/setup_15.x | bash -
apt install nodejs

npm install -g npm

Дополнительная информация:

Установка сертификата на сайт производится простой командой:

letsencrypt -d domain.ru

13) при использовании единого unix-пользователя для всех сайтов (не рекомендуется):

# chown -R username:username /var/www
cd /var/www/
find ./ -type d -exec chmod 4770 {} \;

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

в /var/www создаем директорию с именем будущего хоста (например, drupal.my)

14) в /etc/apache2/sites-available/ создаем файл.conf хоста, например /etc/apache2/sites-available/drupal.my.conf

15) содержимое должно выглядеть таким образом (пример).

*вместо drupal.my везде вписываете имя своего хоста, а вместо username своё имя пользователя в системе

16) активируем наш хост

# a2ensite drupal.my.conf

17) в /etc/hosts записываем наш хост таким образом

127.0.0.1 drupal.my

18) не забываем перезапустить апач

# service apache2 restart

19) При необходимости добавляем поддержку python и модуля requests для него

# apt install python-minimal
apt install python3-pip


Полное удаление lamp из системы:

1)

# apt-get purge libapache2-mod-auth-mysql phpmyadmin

2)

# dpkg -l | grep ^ii | grep mysql-server | awk -F' ' '{ print $2 }'

*команда выведет на экран список пакетов....их все нужно удалить:

# apt-get purge пакет1 пакет2 пакет3

3)

# dpkg -l | grep ^ii | grep apache2 | awk -F' ' '{ print $2 }'

*тоже самое, что и в п.2

4)

# apt-get autoremove

Друзья! Приглашаем вас к обсуждению. Если у вас есть своё мнение, напишите нам в комментарии.