Suggerimenti per una nuova configurazione web server Nginx

Turgut K.Linux1 mese fa65 Visite

Configurare correttamente il file /etc/nginx/nginx.conf è fondamentale per ottimizzare le prestazioni, la sicurezza e l’affidabilità del server web Nginx. Di seguito ti fornisco alcune linee guida e configurazioni consigliate per un file nginx.conf ottimizzato.

1. Configurazione di Base

user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
    worker_connections 1024;
    multi_accept on;
}

http {
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    server_tokens off;

    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    gzip on;
    gzip_disable "msie6";
    gzip_vary on;
    gzip_proxied any;
    gzip_comp_level 6;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}

2. Ottimizzazione delle Prestazioni

  • worker_processes: Imposta il numero di processi worker. Il valore auto permette a Nginx di scegliere automaticamente il numero di core CPU disponibili.
  • worker_connections: Definisce il numero massimo di connessioni simultanee che ogni worker può gestire.
  • multi_accept: Permette a ogni worker di accettare più connessioni alla volta.
  • sendfile: Abilita l’uso di sendfile() per trasferire file direttamente dal disco alla rete, migliorando le prestazioni.
  • tcp_nopush e tcp_nodelay: Ottimizzano l’invio di pacchetti TCP.
  • keepalive_timeout: Definisce il tempo massimo di mantenimento di una connessione keepalive.

3. Sicurezza

  • server_tokens off: Nasconde la versione di Nginx nei header delle risposte, riducendo la superficie di attacco.
  • gzip: Abilita la compressione Gzip per ridurre le dimensioni dei file trasmessi.
  • gzip_types: Specifica i tipi di file da comprimere.

4. Configurazione di un Virtual Host

server {
    listen 80;
    server_name example.com;

    root /var/www/html;
    index index.html index.htm;

    location / {
        try_files $uri $uri/ =404;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
    }

    location ~ /\.ht {
        deny all;
    }

    error_page 404 /404.html;
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /usr/share/nginx/html;
    }
}

5. SSL/TLS Configuration

server {
    listen 443 ssl;
    server_name example.com;

    ssl_certificate /etc/ssl/certs/example.com.crt;
    ssl_certificate_key /etc/ssl/private/example.com.key;

    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers on;

    root /var/www/html;
    index index.html index.htm;

    location / {
        try_files $uri $uri/ =404;
    }
}

6. Load Balancing

upstream backend {
    server 192.168.1.101;
    server 192.168.1.102;
    server 192.168.1.103;
}

server {
    listen 80;
    server_name example.com;

    location / {
        proxy_pass http://backend;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

7. Rate Limiting

http {
    limit_req_zone $binary_remote_addr zone=one:10m rate=1r/s;

    server {
        location /login {
            limit_req zone=one burst=5;
            proxy_pass http://backend;
        }
    }
}

8. Caching

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m use_temp_path=off;

server {
    location / {
        proxy_cache my_cache;
        proxy_pass http://backend;
        proxy_cache_valid 200 302 10m;
        proxy_cache_valid 404 1m;
    }
}

9. Logging

http {
    log_format custom '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log /var/log/nginx/access.log custom;
    error_log /var/log/nginx/error.log;
}

10. Security Headers

server {
    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-Content-Type-Options "nosniff";
    add_header X-XSS-Protection "1; mode=block";
    add_header Content-Security-Policy "default-src 'self';";
}

Conclusioni

Queste configurazioni sono solo un punto di partenza. A seconda del caso d’uso specifico, potresti dover apportare ulteriori modifiche. Ricorda di testare sempre le modifiche in un ambiente di staging prima di applicarle in produzione e di monitorare le prestazioni e la sicurezza del server.

0 Votes: 0 Upvotes, 0 Downvotes (0 Points)

Lascia una risposta

Post precedente

Post successivo

Follow
Registrazione Barra laterale Ricerca Aggiungi link o post
Articoli popolari
Caricamento

Accesso in corso 3 secondi...