2010-08-08 10 views
10

Ho appena impostato nginx per servire la richiesta statica su un sito, ma ho molti siti sul mio server e mi chiedo, dovrei avere il diritto di nuovo configurazione del server nginx per tutti loro? Cosa sto facendo ora. Ho file con tutti gli host voci virtuali per Apache con qualche-cosa come questa:Apache e ultima configurazione per nginx per servire tutti gli host virtuali nel modo giusto

NameVirtualHost *:8080 
<VirtualHost *:8080> 
ServerName sky2high.net 
DocumentRoot /home/mainsiter/data/www/sky2high.net 
</VirtualHost> 

<VirtualHost *:8080> 
ServerName surdo.asmon.ru 
DocumentRoot /home/surdo/data/www/surdo.asmon.ru 
</VirtualHost> 

<VirtualHost *:8080> 
ServerName surdoserver.ru 
DocumentRoot /home/surdo/data/www/surdoserver.ru 
</VirtualHost> 

ho questo in ports.conf di apache:

Listen 8080 

E così ho creato nginx per lavorare con un sito (sky2high.net), creato file successivo configure (/etc/nginx/sites-enabled/sky2high.net):

server { 
listen 80; 
server_name sky2high.net www.sky2high.net; 
    proxy_pass http://127.0.0.1:8000; 
    proxy_set_header Host $host; 

access_log /var/log/nginx.access_log; 

location ~* \.(jpg|jpeg|gif|png|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|tar|wav|bmp|rtf|swf|ico|flv|txt|xml|docx|xlsx)$ { 
    root /home/mainsiter/data/www/sky2high.net/; 
    index index.php; 
    access_log off; 
    expires 30d; 
} 
location ~ /\.ht { 
    deny all; 
} 
location/{ 
    proxy_pass http://127.0.0.1:8080/; 
    proxy_set_header X-Real-IP $remote_addr; 
    proxy_set_header X-Forwarded-for $remote_addr; 
    proxy_set_header Host $host; 
    proxy_connect_timeout 60; 
    proxy_send_timeout 90; 
    proxy_read_timeout 90; 
    proxy_redirect off; 
    proxy_set_header Connection close; 
    proxy_pass_header Content-Type; 
    proxy_pass_header Content-Disposition; 
    proxy_pass_header Content-Length; 
} 
} 

e funziona benissimo per questo dominio, ma naturalmente un altro host virtuali sono rotto.

Quindi, la domanda è: c'è l'ultima opzione di configurazione per nginx, che può aiutare a gestire tutte le richieste, da tutti gli host virtuali (domini) e servirli nel modo giusto? Voglio dire, l'opzione che permette di non scrivere file di configurazione separati per ogni host virtuale (con tutto questo roba raddoppiato come le opzioni di root e index), ma solo uno per tutti gli host virtuali?

PS: devo spostare la domanda su serverfault?

UPDATE: Emm .. Mi chiedo come funziona, ma lo è. Ho fatto file di configurazione seguenti:

/etc/nginx/nginx.conf

user www-data; 
worker_processes 2; 

error_log /var/log/nginx/error.log; 
pid  /var/run/nginx.pid; 

events { 
    worker_connections 1024; 
} 

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

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

    sendfile  on; 
    #tcp_nopush  on; 

    #keepalive_timeout 0; 
    keepalive_timeout 65; 
    tcp_nodelay  on; 

    gzip    on; 
    gzip_min_length 1000; 
    gzip_proxied  any; 
    gzip_disable  "msie6"; 

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

e

/etc/nginx/sites-enabled/default

server { 
    listen 80; 

    location/{ 
     proxy_pass http://127.0.0.1:8080/; 
     proxy_redirect off; 
     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 Connection close; 
     proxy_pass_header Content-Type; 
     proxy_pass_header Content-Disposition; 
     proxy_pass_header Content-Length; 
    } 
} 

I non capisco come funziona, ma è ...

AGGIORNAMENTO 2: o non funziona! Ho cercato di "top" in console e ho verificato che apache serve non solo la richiesta php, ma anche il contenuto statico = (

risposta

7

Quello che fai ora è inviare tutto il traffico di rete a 127.0.0.1:8080 senza consentire Nginx per servire i file statici

Che cosa si dovrebbe provare è il seguente:.

server { 
listen 80; 
server_name sky2high.net www.sky2high.net; 
location/{ 
proxy_pass http://127.0.0.1:8080; 
include /etc/nginx/conf.d/proxy.conf; 
} 
location ~* ^.+\.(jpg|jpeg|gif|png|ico|tgz|gz|pdf|rar|bz2|exe|ppt|txt|tar|mid|midi|wav|bmp|rtf) { 
root /folder/to/static/files; 
expires 90d; 
} 
location ~* ^.+\.(css|js)$ { 
root /folder/to/static/files; 
expires 30d; 
} 

E in proxy.conf mettere il seguente:

proxy_redirect off; 
proxy_set_header Host $host; 
proxy_set_header X-Real-IP $remote_addr; 
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
client_max_body_size 8m; 
client_body_buffer_size 256k; 
proxy_connect_timeout 60; 
proxy_send_timeout 60; 
proxy_read_timeout 60; 
proxy_buffer_size 4k; 
proxy_buffers 32 256k; 
proxy_busy_buffers_size 512k; 
proxy_temp_file_write_size 256k; 

Questo shoul d lavoro per voi

+1

Si potrebbe desiderare di cambiare quella riga: proxy_set_header Host $ host: $ proxy_port; – dalore

2

Solo i miei due centesimi, nella maggior parte dei casi non è necessario specificare il listen 80.

Fonte: Nginx common Pitfalls