Конфигурация nginx для Drupal, Boost и ImageCache - PullRequest
0 голосов
/ 13 июня 2011

UPD !!! : Обсуждаемая здесь проблема полностью решается с помощью этой темы:

http://groups.drupal.org/node/155564

И путем подробного изучения:

Конфигурация Nginx от Nginx & Drupal гуру - Антонио П.П. Алмейда (Perusio).

https://github.com/perusio/drupal-with-nginx

не могу решить следующую проблему: у меня FreeBSD, Apache 2.2, PHP (без FastCGI!) в качестве модуля apache, nginx 0.8.5.4.

Я пытаюсь переместить портал Drupal с включенным boost и image_cacheэто на личный VPS сервер.

Моя цель - переписать clean_url в nginx и исправить правила boost & image_cache.

Пожалуйста, помогите!Я знаю, что с моей текущей конфигурацией nginx что-то не так.Весь день был обрезан.

Вот nginx.conf (только / теперь работает маршрут):

user www www; 
worker_processes  1;

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  /var/log/nginx-access.log  main;

    reset_timedout_connection on;
    sendfile        on;
    aio sendfile;
    tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    gzip  on;

    upstream backend {
        # Apache server
        server 77.72.19.19:81;
    }

    server {
        listen       77.72.19.19:80 default accept_filter=httpready;
        server_name  77.72.19.19;

        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $remote_addr;

        gzip  on;
        gzip_static on;
        gzip_proxied any;

        gzip_types text/plain text/html text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

        set $myroot /usr/local/www/apache22/data/alfa;
        root $myroot;

        location ~ ^\. {
            deny all;
        }

        set $boost "";
        set $boost_query "_";

        if ( $request_method = GET ) {
            set $boost G;
        }

        if ($http_cookie !~ "DRUPAL_UID") {
            set $boost "${boost}D";
        }

        if ($query_string = "") {
            set $boost "${boost}Q";
        }

        if ( -f $myroot/cache/normal/$http_host$request_uri$boost_query$query_string.html ) {
            set $boost "${boost}F";
        }

        if ($boost = GDQF){
            rewrite ^.*$ /cache/normal/$http_host/$request_uri$boost_query$query_string.html break;
        }

        if ( -f $myroot/cache/perm/$http_host$request_uri$boost_query$query_string.css ) {
            set $boost "${boost}F";
        }

        if ($boost = GDQF){
            rewrite ^.*$ /cache/perm/$http_host/$request_uri$boost_query$query_string.css break;
        }

        if ( -f $myroot/cache/perm/$http_host$request_uri$boost_query$query_string.js ) {
            set $boost "${boost}F";
        }

        if ($boost = GDQF){
            rewrite ^.*$ /cache/perm/$http_host/$request_uri$boost_query$query_string.js break;
        }

        location ~ ^/sites/.*/files/imagecache/ {
            #try_files $uri @rewrite;
            error_page 404 = /;
        }

        location ~* \.(txt|jpg|jpeg|css|js|gif|png|bmp|flv|pdf|ps|doc|mp3|wmv|wma|wav|ogg|mpg|mpeg|mpg4|htm|zip|bz2|rar|xls|docx|avi|djvu|mp4|rtf|ico)$ 
        {
            expires max;
            add_header Vary Accept-Encoding;
            if (-f $request_filename) {
                break;
            }
            if (!-f $request_filename) {
                proxy_pass "http://backend";
                break;
            }
        }

        location ~* \.(html(.gz)?|xml)$ {
            add_header Cache-Control no-cache,no-store,must-validate;
            root $myroot;
            if (-f $request_filename) {
                break;
            }
            if (!-f $request_filename) {
                proxy_pass "http://backend";
                break;
            }
        }        

        if (!-e $request_filename) {
            rewrite  ^/(.*)$   /index.php?q=$1  last;
            break;
        }

        location / {
            proxy_pass http://backend;
        } 

     }
}

UPD: С этим nginx.conf у меня работает /.И любая другая страница дает мне: «Страница не перенаправляет должным образом».Кто может объяснить мне порядок, в котором оцениваются правила размещения?И если это «перерыв» - когда nginx встречает эту строку, что он делает дальше.Я действительно попробовал около 20 примеров конфигурации nginx.Мне не нужна еще одна ссылка, я бы предпочел ответы кого-то, кто действительно понимает, что происходит в nginx.conf.

UPD2: Если я заменю

        if (!-e $request_filename) {
            rewrite  ^/(.*)$   /index.php?q=$1  last;
            break;
        }

с:

        try_files $uri $uri/ @drupal;
        location @drupal {
            rewrite ^ /index.php?q=$uri last; # for Drupal 6
        }

Тогда все не-root страницы выдают мне 404 «Запрошенный URL не найден на этом сервере».

Ответы [ 2 ]

0 голосов
/ 14 июня 2011

Настройка nginx следующим образом: https://github.com/stanislaw/config_files/blob/master/nginx.conf привела Drupal к следующему поведению: все работало нормально, если сайт находился в режиме обслуживания.Навигация по всем некорневым URL-адресам (вход с правами администратора) прошла нормально.Но если я переведу сайт в онлайн-режим, то я снова начал получать все, что там есть «Страница перенаправляется неправильно» (сначала UPD).

Затем я протестировал ту же конфигурацию на свежей установке drupal - она ​​работала как в автономном, так и в онлайн-режимах.Навигация по всем clean_urls сработала.

Я думаю, что конфиг действительно работает !, но сайт, который я пытаюсь развернуть, содержит много модулей, которые могут вызвать такие неправильные перенаправления.

Я закончилвплоть до наличия чистых URL в разделе vhosts для моего сайта, оставляя эту проблему на будущее.Моя нынешняя конфигурация очень похожа на конфигурацию на github (см. Ссылку), но она прокомментировала раздел clean_urls (сейчас я использую 'location /' вместо 'location ~ .php').

В любом случае, я быБуду очень благодарен за любые советы и комментарии относительно моего текущего конфига (см. nginx.conf на github - ссылка выше).

UPD: вот соответствующий пост в группе druginal nginx: http://groups.drupal.org/node/155564

0 голосов
/ 13 июня 2011

Ответ 2:

Заменить следующие строки conf

    if (!-e $request_filename) {
        rewrite  ^/(.*)$   /index.php?q=$1  last;
        break;
    }

    location / {
        proxy_pass http://backend;
    }

с этим:

location / {
    root   /path/to/drupal;
    index  index.php index.html;

    if (!-e $request_filename) {
        rewrite  ^/(.*)$  /index.php?q=$1  last;
        break;
    }

}

Вот полезная ссылка:

http://hostingfu.com/article/running-drupal-with-clean-url-on-nginx-or-lighttpd#toc-nginx

Для быстрой информации:

Если drupal устанавливается в корневой каталог,

if (!-e $request_filename) {
rewrite  ^/(.*)$   /index.php?q=$1  last;
 break;
}

Если друпал в подкаталоге,

if ($request_uri ~* ^.*/.*$) {
rewrite ^/(\w*)/(.*)$  /$1/index.php?q=$2 last;
break;
}
...