Настройка Nginx веб-сервера — различия между версиями

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск
 
Строка 11: Строка 11:
  
 
1. Обновите список пакетов:
 
1. Обновите список пакетов:
<code>sudo apt update</code>
+
<pre>sudo apt update</pre>
  
 
2. Установите Nginx:
 
2. Установите Nginx:
<code>sudo apt install nginx</code>
+
<pre>sudo apt install nginx</pre>
  
 
3. Запустите и включите автозапуск Nginx:
 
3. Запустите и включите автозапуск Nginx:
<code>sudo systemctl start nginx</code>
+
<pre>sudo systemctl start nginx</pre>
<code>sudo systemctl enable nginx</code>
+
<pre>sudo systemctl enable nginx</pre>
  
 
=== Для CentOS/RHEL/Fedora ===
 
=== Для CentOS/RHEL/Fedora ===
  
 
1. Установите Nginx:
 
1. Установите Nginx:
<code>sudo yum install nginx</code>
+
<pre>sudo yum install nginx</pre>
 
# или для новых версий
 
# или для новых версий
<code>sudo dnf install nginx</code>
+
<pre>sudo dnf install nginx</pre>
  
 
2. Запустите и включите автозапуск:
 
2. Запустите и включите автозапуск:
<code>sudo systemctl start nginx</code>
+
<pre>sudo systemctl start nginx</pre>
<code>sudo systemctl enable nginx</code>
+
<pre>sudo systemctl enable nginx</pre>
  
 
== 3. Проверка установки ==
 
== 3. Проверка установки ==
Строка 48: Строка 48:
  
 
1. Создайте директорию для вашего сайта:
 
1. Создайте директорию для вашего сайта:
<code>sudo mkdir -p /var/www/example.com/public_html</code>
+
<pre>sudo mkdir -p /var/www/example.com/public_html</pre>
  
 
2. Создайте файл конфигурации сайта:
 
2. Создайте файл конфигурации сайта:
<code>sudo nano /etc/nginx/sites-available/example.com</code>
+
<pre>sudo nano /etc/nginx/sites-available/example.com</pre>
  
 
3. Добавьте следующую конфигурацию:
 
3. Добавьте следующую конфигурацию:
<code>server {</code>
+
<pre>server {</pre>
<code>listen 80;</code>
+
<pre>listen 80;</pre>
<code>server_name example.com www.example.com;</code>
+
<pre>server_name example.com www.example.com;</pre>
<code>root /var/www/example.com/public_html;</code>
+
<pre>root /var/www/example.com/public_html;</pre>
<code>index index.html index.php;</code>
+
<pre>index index.html index.php;</pre>
<code>location / {</code>
+
<pre>location / {</pre>
<code>try_files $uri $uri/ =404;</code>
+
<pre>try_files $uri $uri/ =404;</pre>
<code>}</code>
+
<pre>}</pre>
<code>location ~ \.php$ {</code>
+
<pre>location ~ \.php$ {</pre>
<code>include snippets/fastcgi-php.conf;</code>
+
<pre>include snippets/fastcgi-php.conf;</pre>
<code>fastcgi_pass unix:/var/run/php/php8.1-fpm.sock;</code>
+
<pre>fastcgi_pass unix:/var/run/php/php8.1-fpm.sock;</pre>
<code>}</code>
+
<pre>}</pre>
<code>location ~ /\.ht {</code>
+
<pre>location ~ /\.ht {</pre>
<code>deny all;</code>
+
<pre>deny all;</pre>
<code>}</code>
+
<pre>}</pre>
<code>}</code>
+
<pre>}</pre>
  
 
4. Создайте символическую ссылку для активации сайта:
 
4. Создайте символическую ссылку для активации сайта:
<code>sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/</code>
+
<pre>sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/</pre>
  
 
5. Проверьте конфигурацию:
 
5. Проверьте конфигурацию:
<code>sudo nginx -t</code>
+
<pre>sudo nginx -t</pre>
  
 
6. Перезапустите Nginx:
 
6. Перезапустите Nginx:
<code>sudo systemctl restart nginx</code>
+
<pre>sudo systemctl restart nginx</pre>
  
 
== 5. Настройка PHP-FPM ==
 
== 5. Настройка PHP-FPM ==
Строка 85: Строка 85:
  
 
1. Установите PHP и PHP-FPM:
 
1. Установите PHP и PHP-FPM:
<code>sudo apt install php-fpm php-mysql php-curl php-gd php-mbstring php-xml php-zip</code>
+
<pre>sudo apt install php-fpm php-mysql php-curl php-gd php-mbstring php-xml php-zip</pre>
  
 
2. Запустите PHP-FPM:
 
2. Запустите PHP-FPM:
<code>sudo systemctl start php8.1-fpm</code>
+
<pre>sudo systemctl start php8.1-fpm</pre>
<code>sudo systemctl enable php8.1-fpm</code>
+
<pre>sudo systemctl enable php8.1-fpm</pre>
  
 
=== Настройка PHP-FPM для Nginx ===
 
=== Настройка PHP-FPM для Nginx ===
  
 
1. Отредактируйте конфигурацию PHP-FPM:
 
1. Отредактируйте конфигурацию PHP-FPM:
<code>sudo nano /etc/php/8.1/fpm/pool.d/www.conf</code>
+
<pre>sudo nano /etc/php/8.1/fpm/pool.d/www.conf</pre>
  
 
2. Найдите и измените следующие параметры:
 
2. Найдите и измените следующие параметры:
<code>listen = /var/run/php/php8.1-fpm.sock</code>
+
<pre>listen = /var/run/php/php8.1-fpm.sock</pre>
<code>listen.owner = www-data</code>
+
<pre>listen.owner = www-data</pre>
<code>listen.group = www-data</code>
+
<pre>listen.group = www-data</pre>
<code>listen.mode = 0660</code>
+
<pre>listen.mode = 0660</pre>
  
 
3. Перезапустите PHP-FPM:
 
3. Перезапустите PHP-FPM:
<code>sudo systemctl restart php8.1-fpm</code>
+
<pre>sudo systemctl restart php8.1-fpm</pre>
  
 
== 6. Настройка SSL сертификатов ==
 
== 6. Настройка SSL сертификатов ==
Строка 110: Строка 110:
  
 
1. Установите Certbot:
 
1. Установите Certbot:
<code>sudo apt install certbot python3-certbot-nginx</code>
+
<pre>sudo apt install certbot python3-certbot-nginx</pre>
  
 
2. Получите SSL сертификат:
 
2. Получите SSL сертификат:
<code>sudo certbot --nginx -d example.com -d www.example.com</code>
+
<pre>sudo certbot --nginx -d example.com -d www.example.com</pre>
  
 
3. Проверьте автоматическое обновление:
 
3. Проверьте автоматическое обновление:
<code>sudo certbot renew --dry-run</code>
+
<pre>sudo certbot renew --dry-run</pre>
  
 
== 7. Оптимизация производительности ==
 
== 7. Оптимизация производительности ==
Строка 123: Строка 123:
  
 
1. Добавьте в конфигурацию сайта:
 
1. Добавьте в конфигурацию сайта:
<code>location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {</code>
+
<pre>location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {</pre>
<code>expires 1y;</code>
+
<pre>expires 1y;</pre>
<code>add_header Cache-Control "public, immutable";</code>
+
<pre>add_header Cache-Control "public, immutable";</pre>
<code>}</code>
+
<pre>}</pre>
<code>gzip on;</code>
+
<pre>gzip on;</pre>
<code>gzip_vary on;</code>
+
<pre>gzip_vary on;</pre>
<code>gzip_min_length 1024;</code>
+
<pre>gzip_min_length 1024;</pre>
<code>gzip_types text/plain text/css text/xml text/javascript application/javascript application/xml+rss application/json;</code>
+
<pre>gzip_types text/plain text/css text/xml text/javascript application/javascript application/xml+rss application/json;</pre>
  
 
=== Настройка worker процессов ===
 
=== Настройка worker процессов ===
  
 
1. Отредактируйте основной файл конфигурации:
 
1. Отредактируйте основной файл конфигурации:
<code>sudo nano /etc/nginx/nginx.conf</code>
+
<pre>sudo nano /etc/nginx/nginx.conf</pre>
  
 
2. Настройте параметры:
 
2. Настройте параметры:
<code>worker_processes auto;</code>
+
<pre>worker_processes auto;</pre>
<code>worker_connections 1024;</code>
+
<pre>worker_connections 1024;</pre>
<code>keepalive_timeout 65;</code>
+
<pre>keepalive_timeout 65;</pre>
<code>client_max_body_size 100M;</code>
+
<pre>client_max_body_size 100M;</pre>
  
 
== 8. Настройка файрвола ==
 
== 8. Настройка файрвола ==
Строка 148: Строка 148:
  
 
1. Разрешите HTTP и HTTPS трафик:
 
1. Разрешите HTTP и HTTPS трафик:
<code>sudo ufw allow 'Nginx Full'</code>
+
<pre>sudo ufw allow 'Nginx Full'</pre>
  
 
=== Для CentOS/RHEL (firewalld) ===
 
=== Для CentOS/RHEL (firewalld) ===
  
 
1. Разрешите HTTP и HTTPS:
 
1. Разрешите HTTP и HTTPS:
<code>sudo firewall-cmd --permanent --add-service=http</code>
+
<pre>sudo firewall-cmd --permanent --add-service=http</pre>
<code>sudo firewall-cmd --permanent --add-service=https</code>
+
<pre>sudo firewall-cmd --permanent --add-service=https</pre>
<code>sudo firewall-cmd --reload</code>
+
<pre>sudo firewall-cmd --reload</pre>
  
 
== 9. Управление Nginx ==
 
== 9. Управление Nginx ==
Строка 162: Строка 162:
  
 
* '''Запуск Nginx''':
 
* '''Запуск Nginx''':
<code>sudo systemctl start nginx</code>
+
<pre>sudo systemctl start nginx</pre>
  
 
* '''Остановка Nginx''':
 
* '''Остановка Nginx''':
<code>sudo systemctl stop nginx</code>
+
<pre>sudo systemctl stop nginx</pre>
  
 
* '''Перезапуск Nginx''':
 
* '''Перезапуск Nginx''':
<code>sudo systemctl restart nginx</code>
+
<pre>sudo systemctl restart nginx</pre>
  
 
* '''Перезагрузка конфигурации''':
 
* '''Перезагрузка конфигурации''':
<code>sudo systemctl reload nginx</code>
+
<pre>sudo systemctl reload nginx</pre>
  
 
* '''Проверка статуса''':
 
* '''Проверка статуса''':
<code>sudo systemctl status nginx</code>
+
<pre>sudo systemctl status nginx</pre>
  
 
* '''Проверка конфигурации''':
 
* '''Проверка конфигурации''':
<code>sudo nginx -t</code>
+
<pre>sudo nginx -t</pre>
  
 
== 10. Мониторинг и логи ==
 
== 10. Мониторинг и логи ==
Строка 184: Строка 184:
  
 
* '''Логи ошибок''':
 
* '''Логи ошибок''':
<code>sudo tail -f /var/log/nginx/error.log</code>
+
<pre>sudo tail -f /var/log/nginx/error.log</pre>
  
 
* '''Логи доступа''':
 
* '''Логи доступа''':
<code>sudo tail -f /var/log/nginx/access.log</code>
+
<pre>sudo tail -f /var/log/nginx/access.log</pre>
  
 
* '''Все логи Nginx''':
 
* '''Все логи Nginx''':
<code>sudo tail -f /var/log/nginx/*.log</code>
+
<pre>sudo tail -f /var/log/nginx/*.log</pre>
  
 
=== Мониторинг производительности ===
 
=== Мониторинг производительности ===
  
 
1. Установите htop для мониторинга:
 
1. Установите htop для мониторинга:
<code>sudo apt install htop</code>
+
<pre>sudo apt install htop</pre>
  
 
2. Запустите мониторинг:
 
2. Запустите мониторинг:
<code>htop</code>
+
<pre>htop</pre>
  
 
== 11. Безопасность ==
 
== 11. Безопасность ==
Строка 205: Строка 205:
  
 
1. Скрыть версию Nginx:
 
1. Скрыть версию Nginx:
<code>server_tokens off;</code>
+
<pre>server_tokens off;</pre>
  
 
2. Настроить ограничения:
 
2. Настроить ограничения:
<code>client_max_body_size 10M;</code>
+
<pre>client_max_body_size 10M;</pre>
<code>client_body_timeout 12;</code>
+
<pre>client_body_timeout 12;</pre>
<code>client_header_timeout 12;</code>
+
<pre>client_header_timeout 12;</pre>
<code>keepalive_timeout 15;</code>
+
<pre>keepalive_timeout 15;</pre>
<code>send_timeout 10;</code>
+
<pre>send_timeout 10;</pre>
  
 
3. Настроить права доступа:
 
3. Настроить права доступа:
<code>sudo chown -R www-data:www-data /var/www/</code>
+
<pre>sudo chown -R www-data:www-data /var/www/</pre>
<code>sudo chmod -R 755 /var/www/</code>
+
<pre>sudo chmod -R 755 /var/www/</pre>
  
 
== Заключение ==
 
== Заключение ==

Текущая версия на 10:34, 15 октября 2025

Настройка Nginx веб-сервера

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Обновите систему до последней версии пакетов.

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

Для Ubuntu/Debian

1. Обновите список пакетов:

sudo apt update

2. Установите Nginx:

sudo apt install nginx

3. Запустите и включите автозапуск Nginx:

sudo systemctl start nginx
sudo systemctl enable nginx

Для CentOS/RHEL/Fedora

1. Установите Nginx:

sudo yum install nginx
  1. или для новых версий
sudo dnf install nginx

2. Запустите и включите автозапуск:

sudo systemctl start nginx
sudo systemctl enable nginx

3. Проверка установки

1. Откройте веб-браузер и перейдите по адресу http://ваш-ip-адрес или http://localhost. 2. Вы должны увидеть страницу приветствия Nginx.

4. Базовая настройка Nginx

Структура конфигурационных файлов

  • Основной файл конфигурации: `/etc/nginx/nginx.conf`
  • Директория сайтов: `/etc/nginx/sites-available/`
  • Активные сайты: `/etc/nginx/sites-enabled/`
  • Директория логов: `/var/log/nginx/`

Создание виртуального хоста

1. Создайте директорию для вашего сайта:

sudo mkdir -p /var/www/example.com/public_html

2. Создайте файл конфигурации сайта:

sudo nano /etc/nginx/sites-available/example.com

3. Добавьте следующую конфигурацию:

server {
listen 80;
server_name example.com www.example.com;
root /var/www/example.com/public_html;
index index.html index.php;
location / {
try_files $uri $uri/ =404;
}
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/var/run/php/php8.1-fpm.sock;
}
location ~ /\.ht {
deny all;
}
}

4. Создайте символическую ссылку для активации сайта:

sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/

5. Проверьте конфигурацию:

sudo nginx -t

6. Перезапустите Nginx:

sudo systemctl restart nginx

5. Настройка PHP-FPM

Установка PHP-FPM

1. Установите PHP и PHP-FPM:

sudo apt install php-fpm php-mysql php-curl php-gd php-mbstring php-xml php-zip

2. Запустите PHP-FPM:

sudo systemctl start php8.1-fpm
sudo systemctl enable php8.1-fpm

Настройка PHP-FPM для Nginx

1. Отредактируйте конфигурацию PHP-FPM:

sudo nano /etc/php/8.1/fpm/pool.d/www.conf

2. Найдите и измените следующие параметры:

listen = /var/run/php/php8.1-fpm.sock
listen.owner = www-data
listen.group = www-data
listen.mode = 0660

3. Перезапустите PHP-FPM:

sudo systemctl restart php8.1-fpm

6. Настройка SSL сертификатов

Установка Certbot

1. Установите Certbot:

sudo apt install certbot python3-certbot-nginx

2. Получите SSL сертификат:

sudo certbot --nginx -d example.com -d www.example.com

3. Проверьте автоматическое обновление:

sudo certbot renew --dry-run

7. Оптимизация производительности

Настройка кэширования

1. Добавьте в конфигурацию сайта:

location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {
expires 1y;
add_header Cache-Control "public, immutable";
}
gzip on;
gzip_vary on;
gzip_min_length 1024;
gzip_types text/plain text/css text/xml text/javascript application/javascript application/xml+rss application/json;

Настройка worker процессов

1. Отредактируйте основной файл конфигурации:

sudo nano /etc/nginx/nginx.conf

2. Настройте параметры:

worker_processes auto;
worker_connections 1024;
keepalive_timeout 65;
client_max_body_size 100M;

8. Настройка файрвола

Для Ubuntu/Debian (ufw)

1. Разрешите HTTP и HTTPS трафик:

sudo ufw allow 'Nginx Full'

Для CentOS/RHEL (firewalld)

1. Разрешите HTTP и HTTPS:

sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo firewall-cmd --reload

9. Управление Nginx

Основные команды управления

  • Запуск Nginx:
sudo systemctl start nginx
  • Остановка Nginx:
sudo systemctl stop nginx
  • Перезапуск Nginx:
sudo systemctl restart nginx
  • Перезагрузка конфигурации:
sudo systemctl reload nginx
  • Проверка статуса:
sudo systemctl status nginx
  • Проверка конфигурации:
sudo nginx -t

10. Мониторинг и логи

Просмотр логов

  • Логи ошибок:
sudo tail -f /var/log/nginx/error.log
  • Логи доступа:
sudo tail -f /var/log/nginx/access.log
  • Все логи Nginx:
sudo tail -f /var/log/nginx/*.log

Мониторинг производительности

1. Установите htop для мониторинга:

sudo apt install htop

2. Запустите мониторинг:

htop

11. Безопасность

Базовая настройка безопасности

1. Скрыть версию Nginx:

server_tokens off;

2. Настроить ограничения:

client_max_body_size 10M;
client_body_timeout 12;
client_header_timeout 12;
keepalive_timeout 15;
send_timeout 10;

3. Настроить права доступа:

sudo chown -R www-data:www-data /var/www/
sudo chmod -R 755 /var/www/

Заключение

Nginx веб-сервер успешно установлен и настроен! Теперь вы можете размещать высокопроизводительные веб-сайты.

Для размещения ваших проектов на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой Nginx и оптимизацией производительности вашего сервера!