ПРОЕКТЫ 


  АРХИВ 


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: proxy_next_upstream http_403 code


  • To: nginx-ru@xxxxxxxxx
  • Subject: Re: proxy_next_upstream http_403 code
  • From: Alex Belyansky <alex.barut@xxxxxxxxx>
  • Date: Tue, 23 Apr 2013 10:27:45 +0400
  • Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=x-received:message-id:date:from:user-agent:mime-version:to:subject :references:in-reply-to:content-type; bh=NEZOzInr+pwDwNxjfZ2NFEcjDjKnMYhMP28x/Y02gFo=; b=vanxm3piW1p+aKp09cYjRPWKPDJBzhd2OKOBTNeKsTecaEtmRexNtibkic2iwXRZn/ hE+M4bVFFAqj31VW0ZysL+a/jwnmug3kaftktZXxwamzmreDV2Te0/dSFh9DgKdstO7m BQksG45pJY1ysPbH81HO2Z1xAreqlDnSEsaYg3shI+KYmqfA91pO41IT14I5As+7Hw4C sHM8euKPgbxtyLOvA+TiGKG0kyR/WFY/YO0/Q0m2g+Hp3eU63vicm+NOw9/cyjljY83V L+GaQqvlzJQUlmAeEnJat2zKR9dla4xyC+HvszfdHLP8OkpPOmuNQAPepvz37VdV36jP MRyQ==
  • In-reply-to: <CAOfwqxVHirf8pds8hwFj_7==m4aQ-AwVMwAvRKcH7MUxOrwxfA@mail.gmail.com>
  • References: <CAOfwqxVM7duiYyrqjOMgTucCCNVJO-oVZ540bTz4Am8Jyo6GLQ@mail.gmail.com> <alpine.BSF.2.00.1304222332240.46227@woozle.rinet.ru> <CAOfwqxVHirf8pds8hwFj_7==m4aQ-AwVMwAvRKcH7MUxOrwxfA@mail.gmail.com>

А чем не устраивает

recursive_error_pages on;
error_page 403 = @upstream;

location @upstream {
    proxy_pass    http://upstream;
}

Насколько я понял документацию, то при возникновении 403-ей от сервера в апстриме nginx снова передаст ее туда же, но уже скорее всего на другой из бекендов.

Поправьте если я ошибаюсь.

On 23.04.2013 09:30, Aleksey Chirkin wrote:
Я наблюдал за тем как работает rsync и заметил что на время копирования он блокирует доступ к директории устанавливая ей chmod 600, после выполнения синхронизации он устанавливает правильные права доступа. Вот в этот промежуток копирования и нужно перехватывать 403. Может я не понял вопроса? Вроде все делаю правильно.


22 апреля 2013 г., 23:33 пользователь Dmitry Morozovsky <marck@xxxxxxxx> написал:
On Mon, 22 Apr 2013, Aleksey Chirkin wrote:

> В моей конфигурации nginx раздает файлы и балансирует нагрузку между
> серверами.
> Я использую rsync для синхронизации данных между машинами.
> Во время синхронизации rsync назначает chmod 600 на синхронизируемые
> директории. Nginx отвечает кодом 403 т.к. ресурс не достижим из-за
> ограниченных привилегий.
> Я хотел бы перехватить код 403 и перенаправить запрос на другой сервер.
>
> Не могли бы вы добавить поддержку кода 403 в proxy_next_upstream директиве?

Простите за нескромный вопрос, а *зачем* вы так делаете?

Если не предпринимать специальных усилий, то новые файлы в процессе rsync
появляются на месте атомарно -- всё должно работать и так.

--
Sincerely,
D.Marck                                     [DM5020, MCK-RIPE, DM3-RIPN]
[ FreeBSD committer:                                 marck@xxxxxxxxxxx ]
------------------------------------------------------------------------
*** Dmitry Morozovsky --- D.Marck --- Wild Woozle --- marck@xxxxxxxx ***
------------------------------------------------------------------------

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



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

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


 




Copyright © Lexa Software, 1996-2009.