Home

ITA - Nginx : abilitare le cartelle dei siti

linux

Introduzione

Come già raccontato in questo articolo sono molto legato al pattern delle cartelle dei siti disponibili e abilitati, di seguito ho descrtitto come procedere con Nginx.

Procedura

Il primo step consiste nella creazione delle cartelle:

$ mkdir /etc/nginx/sites-availbles
$ mkdir /etc/nginx/sites-enabled

Lo step successivo consiste nello spittare il file di configurazione fornito di default nei seguenti due:

::::::::::::::
/etc/nginx/nginx.conf
::::::::::::::
#user html;
worker_processes 1;

#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#pid logs/nginx.pid;

events {
    worker_connections 1024;
}

http {
    include mime.types;
    default_type application/octet-stream;
    
    #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
    # '$status $body_bytes_sent "$http_referer" '
    # '"$http_user_agent" "$http_x_forwarded_for"';
    
    #access_log logs/access.log main;
    
    sendfile on;
    
    #tcp_nopush on;
    #keepalive_timeout 0;                    
    keepalive_timeout 65;                    

    #gzip on;                                

    include sites-enabled/*.conf;
}

e il file del virtual host di default

::::::::::::::
/etc/nginx/sites-availbles/default.conf
::::::::::::::
server {
    listen 80;
    server_name localhost;

    #charset koi8-r;

    #access_log logs/host.access.log main;

    location / {
        root /usr/share/nginx/html;
        index index.html index.htm;
    }

    #error_page 404 /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    # proxy_pass http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    # root html;
    # fastcgi_pass 127.0.0.1:9000;
    # fastcgi_index index.php;
    # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
    # include fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    # deny all;
    #}
}

# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;

# location / {
# root html;
# index index.html index.htm;
# }
#}


# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;

# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;

# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;

# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;

# location / {
# root html;
# index index.html index.htm;
# }
#}

Prima di avviare il servizio controlliamo che la configurazione sia avvenuta con successo :

$ nginx -t

Per abilitare un sito user il seguente pattern

$ ln -s /etc/nginx/sites-availbles/default.conf /etc/nginx/sites-enabled/
$ nginx -t
$ systemctl reload nginx

Riferimenti