Acabo de configurar nginx para atender solicitudes estáticas en un sitio, pero tengo muchos sitios en mi servidor y me pregunto si debería hacerlo correctamente. configuración del servidor nginx para todos ellos? Lo que estoy haciendo ahora. Tengo archivo con todas las entradas hosts virtuales para Apache con alguna-cosa como esta:Apache y última configuración para que nginx sirva a todos los hosts virtuales de la manera correcta
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>
tengo esto en ports.conf de Apache:
Listen 8080
Y por lo que he preparado para trabajar nginx con un sitio (sky2high.net), creado el archivo siguiente configuración (/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;
}
}
Y funciona bien para este dominio, pero, por supuesto, otros hosts virtuales son roto.
Entonces, la pregunta es: ¿existe la última opción de configuración para nginx, que puede ayudar a manejar todas las solicitudes, desde todos los hosts virtuales (dominios) y servirlos de la manera correcta? Es decir, una opción que permite no escribir archivos de configuración separados para cada host virtual (con todo esto duplicado como opciones de raíz e índice), ¿pero solo uno para todos los hosts virtuales?
PD: ¿Debo mover la pregunta a serverfault?
ACTUALIZACIÓN: Emm .. Me pregunto cómo funciona, pero lo es. He hecho los archivos de configuración siguientes:
/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/*;
}
y
/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 no entiendo cómo funciona, pero es ...
ACTUALIZACIÓN 2: o no funciona! He buscado "arriba" en la consola y mencioné que apache no solo sirve para php, sino también para contenido estático = (
Es posible que desee cambiar la una línea a: proxy_set_header anfitrión $ host: $ proxy_port; – dalore