Apache и лучшая конфигурация для nginx для правильного обслуживания всех виртуальных хостов - PullRequest
10 голосов
/ 08 августа 2010

Я только что настроил nginx для обслуживания статического запроса на одном сайте, но у меня много сайтов на моем сервере, и мне интересно, должен ли я выбрать новую конфигурацию сервера nginx для всех них?Чем я сейчас занимаюсь.У меня есть файл со всеми записями виртуальных хостов для Apache с чем-то вроде этого:

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>

У меня есть это в портах apache.conf:

Listen 8080

И поэтому я установилдо nginx для работы с одним сайтом (sky2high.net), создал следующий файл конфигурации (/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;
 }
} 

И он отлично работает для этого домена, ноконечно, другие виртуальные хосты сломаны.

Итак, вопрос в том, есть ли конечная опция конфигурации для nginx, ведьма может помочь обработать все запросы со всех виртуальных хостов (доменов) и правильно обслуживать их.?Я имею в виду опцию, которая позволяет не записывать отдельные файлы конфигурации для каждого виртуального хоста (со всеми этими удвоенными вещами, такими как параметры корня и индекса), но только один для всех виртуальных хостов?

PS: я должен переместить вопрос вserverfault?

ОБНОВЛЕНИЕ: Эмм .. Интересно, как это работает, но это так.Я сделал следующие файлы конфигурации:

/ 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/*;
}

и

/ 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;
    }
}

Я не понимаю, как это работает, но это ...

ОБНОВЛЕНИЕ 2: или это не работает!Я посмотрел "top" в консоли и заметил, что apache обслуживает не только php-запрос, но и статический контент = = *

Ответы [ 2 ]

7 голосов
/ 14 октября 2010

Теперь вы отправляете весь сетевой трафик на 127.0.0.1:8080, не позволяя Nginx обслуживать статические файлы.

Вам следует попробовать следующее:

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;
}

И в proxy.conf вы помещаете следующее:

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;

Это должно работать для вас

2 голосов
/ 27 февраля 2011

Просто мои два цента, в большинстве случаев нет необходимости указывать listen 80.

Источник: Общие ошибки Nginx

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...