Russian Apache Switch to English
Switch to Russian koi8-r
windows=1251
cp-866
iso8859-5
Russian Apache Как это работает Рекоммендации Где взять Как установить Как настроить Статус и поддержка
Краткий обзор FAQ Список рассылки Благодарности Поиск по серверу Powered by Russian Apache
Russian Apache mailing list archive (apache-rus@lists.lexa.ru)

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

[apache-talk] Re: [apache-talk] Re: [apache-talk] кнопка Stop б роузера и ProxyPass



On Fri, Sep 07, 2001 at 03:41:07PM +0400, Igor Sysoev wrote:
> On Fri, 7 Sep 2001, Dmitriy Beloslyudtsev wrote:
> 
> > On Fri, Sep 07, 2001 at 12:37:07PM +0400, Igor Sysoev wrote:
> > > On Thu, 6 Sep 2001, Dmitriy Beloslyudtsev wrote:
> > > 
> > > > Когда пользователь прерывает выдачу какой-либо cgi-программы нажав
> > > > кнопку Stop в броузере, то httpd посылает этой cgi-программе SIGINT.
> > > > Так бывает, когда cgi-программа была вызвана "напрямую". Если же
> > > > использовался промежуточный хост (frontend), работающий в режиме
> > > > ProxyPass, то работающая на backend cgi-программа ничего не получает
> > > > и продолжает работать как ни в чем не бывало.
> > > > Можно ли это вылечить? Хотелось бы чтобы ненужные cgi-программы
> > > > обнаруживали такое событие и могли бы честно закончиться.
> > > 
> > > Вообще, судя по беглому коду mod_proxy в этом месте, при обрыве
> > > соединения с клиентом mod_proxy закрывает соединение с бэкендом,
> > > так что вроде бы разницы никакой.
> > > Единственное, если ответ кэшируется, то он может быть получен полностью.
> > 
> > Уже разобрались. Это ошибка в коде mod_proxy, если кэширование выключено
> > (а у нас стоит NoCache *), то нет выхода из цикла чтения (переменная ok
> > не переназначается). Файл src/modules/proxy/proxy_util.c, в районе строки 594.
> 
> А почему это создавало проблему ? cgi очень медленно выдаёт ?
> Потому что, по идее, после того, как клиент обрывает соединение,
> mod_proxy может очень быстро считать весь ответ бэкенда.

Просто cgi-программы делают очень интенсивные вычисления и дают большой вывод.
Пользователь сдуру не туда сунулся, увидел большую выдачу и нажал Stop.
А cgi-программа продолжает работать и занимать процессора, которых не хватает.
Тут-то ей и самое время помереть. А ей никто не говорил.
Август кончился, начался сезонный пик активности, надо все крохи выжимать.

Дима.
=============================================================================
=               Apache-Talk@xxxxxxxxxxxxx mailing list                      =
Mail "unsubscribe apache-talk" to majordomo@xxxxxxxxxxxxx if you want to quit.
=       Archive avaliable at http://www.lexa.ru/apache-talk                 =






Спонсоры сайта:

[ Russian Apache ] [ Как это работает ] [ Рекомендации ] [ Где взять ] [ Как установить ] [ Как настроить ] [ Статус и поддержка ] [ Краткий обзор ] [ FAQ ] [ Список рассылки ] [ Благодарности ] [ Поиск по серверу ] [ Powered by Russian Apache ] [ Apache-talk archive ]

"Russian Apache" includes software developed by the Apache Group for use in the Apache HTTP server project (http://www.apache.org/) See Apache LICENSE.
Copyright (C) 1995-2001 The Apache Group. All rights reserved.
Copyright (C) 1996 Dm. Kryukov; Copyright (C) 1997-2009 Alex Tutubalin. Design (C) 1998 Max Smolev.