ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Уточнение логики работы ngx_http_auth_request_module


  • To: nginx-ru@xxxxxxxxx
  • Subject: Re: Уточнение логики работы ngx_http_auth_request_module
  • From: Dzmitry Stremkouski <mitroko@xxxxxxxxx>
  • Date: Wed, 6 Nov 2013 00:03:25 +0400
  • Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :content-type; bh=89xxzDOrqdPAwO4eEeo8ZUaxLw0+lIjddyHO6wUHJ4c=; b=Nc30/phuXZW7gPxkFYUqeXj1xDDwygG2C5RXklL1c03H8/mtljUaS3hc8JVAUkED6l IJgkoI2ULeWokRHcagiA4sd0iUeNN1YsYR8BVEvKlkQCva3CDRlRgprA2TBqYNCi86RJ mCLmpTzSyzQOA6Ms1otqvyD3kqtd3dW4rSjEPWMHhGiZOjEr6pSPNplrKvOLxFqTeyLF 9qw66SDz2domUFaSOjBfytv13VaiioAc3YVPq2WiM+aEUnRHpBOHN2hxDQ1vG3683ECx HhJPHwg+G862ZC2yCLaB2MKN03soMwwF1tBIVlS/wpG0VMqXpPcSgVi6JA1Xjd8h0vwT a7Cw==
  • In-reply-to: <20131105140841.GU95765@mdounin.ru>
  • References: <CAKoLS4c2b-XxMPmU0BsoLu4eVZiDjUx9crM6PFAZb-aSkg7qGw@mail.gmail.com> <20131104201959.GL95765@mdounin.ru> <CAKoLS4dZJ=_78UXpYYqR2EamTJJe9q2P23q=8Kd2f3uTiRjeHQ@mail.gmail.com> <20131105140841.GU95765@mdounin.ru>

Максим, спасибо огромное за подсказку с satisfy.
Гораздо удобнее геомапинга.

Я немного поэкспериментировал и выяснил, что nginx подвисает в подзапросе, если прилетает POST запрос.
Я вставил следующее правило:
  location /auth {
    if ( $request_method = POST ) { return 200; }

И все приложения заработали, как положено. Бэкенд отлично справляется с нагрузкой, дело не в нём.
Видимо, когда приходит запрос на .https://ssl.stremki.net/project_name методом POST, то ngx_http_auth_request_module 
хочет сделать подзапрос таким же методом.

Но, мало того, что он хочет это сделать, он зачем-то добавляет знак ? в конец локейшна /auth (это видно в дебаглоге)
На стороне бэкенда в этот момент не видно никакого трафика от nginx.
Тоесть, как только прилетает POST с данными на любой локейшн, который проверяется вашим модулем, nginx строит подзапрос с методом POST, добавляет символ ? и не делает подзапрос к бэкенду.

Простите, если запутал.




2013/11/5 Maxim Dounin <mdounin@xxxxxxxxxx>
Hello!

On Tue, Nov 05, 2013 at 02:40:17PM +0400, Dzmitry Stremkouski wrote:

> Максим, спасибо за ваш ответ.
> Я попробовал сделать апгрейд nginx по вашему замечанию, чтобы сузить
> область поиска ошибки.
>
> На данный момент у меня сборка следующая:
> nginx version: nginx/1.5.6
> built by gcc 4.4.5 (Debian 4.4.5-8)
> TLS SNI support enabled
> configure arguments: --with-openssl=/usr/build/openssl-1.0.1e
> --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log
> --http-client-body-temp-path=/var/lib/nginx/body
> --http-fastcgi-temp-path=/var/lib/nginx/fastcgi
> --http-log-path=/var/log/nginx/access.log
> --http-proxy-temp-path=/var/lib/nginx/proxy
> --lock-path=/var/lock/nginx.lock --pid-path=/var/run/nginx.pid --with-debug
> --with-http_flv_module --with-http_geoip_module
> --with-http_gzip_static_module --with-http_realip_module
> --with-http_stub_status_module --with-http_ssl_module
> --with-http_sub_module --with-mail --with-mail_ssl_module
> --add-module=/usr/build/nginx-upstream-fair-master --with-http_spdy_module
> --with-http_auth_request_module
>
> Все симптомы остались прежними.
> CGI скрипты нагиоса работают через такую связку отлично, как и ранее.
> однако, другие приложения (owncloud, roundcube) требуют "медленного"
> прохода.
> Ещё сделал различие, что нагиос работает везде GET запросами, в то время,
> как owncloud, jenkins, roundcube делают периодически POST
> Возможно, это неверно как-то обрабатывается.
>
> Дополнительно, я попытался смягчить условия для мониторинга, прописал в
> http секцию
>
>   geo $ip_range {
>     default 0;
>     192.168.125.0/24 1;
>   }
>
> и в секциях server/location
>
>   set $auth_location /auth/;
>   if ( $ip_range = 1 ) {
>     set $auth_location /always_ok;
>   }
>
>   location = /always_ok {
>     return 200;
>   }
>
>   location /jenkins {
>     auth_request          $auth_location;
>     proxy_pass              http://192.168.125.37:8080;
>     proxy_buffering         on;
>     proxy_set_header        SSL NO;
>     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_read_timeout      1800;
>   }
>
> такая связка не работает.
> Ошибка в логе всё та же. auth_request зачем-то ищет файл $auth_location а
> не делает подзапрос в локейшн возращаемый переменной.
>
> 2013/11/05 13:17:13 [error] 32126#0: *1243 open()
> "/usr/local/nginx/html$auth_location" failed (2: No such file or
> directory), client: 185.6.244.255, server: ssl.stremki.net, request: "GET
> /jenkins/login?from=%2Fjenkins%2F HTTP/1.1", subrequest: "$auth_location",
> host: "ssl.stremki.net", referrer: "https://ssl.stremki.net/jenkins/"
> 2013/11/05 13:17:13 [error] 32126#0: *1243 auth request unexpected status:
> 404, client: 185.6.244.255, server: ssl.stremki.net, request: "GET
> /jenkins/login?from=%2Fjenkins%2F HTTP/1.1", host: "ssl.stremki.net",
> referrer: "https://ssl.stremki.net/jenkins/"
>
> Я включил дебаг для своего адреса. Вот, его вывод.
> http://pastebin.com/aKDG4gYk

Директива auth_request не понимает переменных, и ваша конфигурация
ожидаемо пытается обратиться к файлу, которого не существует.

Правильное решение исходной задачи "разрешить свою сеть, для
остальных - требовать авторизацию" - написать что-нибудь вроде:

    location / {
        satisfy any;

        auth_request /auth;

        allow 192.168.125.0/24;
        deny all;

        ...
    }

http://nginx.org/r/satisfy

Что конкретно у вас происходит в случае, когда конфигурация
работоспособна и помогает "замедление" - надо смотреть, но скорее
всего просто авторизационный бекенд не справляется с нагрузкой.

--
Maxim Dounin
http://nginx.org/en/donation.html

_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru



--
<pre>
(o_ - Dzmitry Stremkouski.
//\ - cel: +7 (916) 090-85-68
V_/_- web: http://mitroko.com
</pre>
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.