Re: Catalyst: увеличиваем скорость реакции
Ivan Иван
solodbeer at yandex.ru
Mon Sep 13 12:30:39 PDT 2010
13.09.10, 22:36, "Alexandr Ciornii" <alexchorny at gmail.com>:
> 13 сентября 2010 г. 19:54 пользователь Sergeev Serge написал:
> > 13.09.10, 02:27, "Alexandr Ciornii" :
>
> >> > Вообще в Перл 5 к сожалению (в отличие от ПХП) есть только один метод разблокировать клиента и продолжить фоновое выполнение - это форк (запускается копия текущего процесса, а затем эта копия отсоединяется от текущего процесса, а сам текущий процесс завершается и отпускает клиента).
> >>
> >> Насколько я помню, close(STDOUT); позволяет продолжить выполнение
> >> после полной отдачи страницы. А как в PHP это можно сделать?
> >
> > Как раз в PHP оно именно где-то так, просто и делается.
>
> Даже если PHP запущен как mod_php или под FastCGI?
>
> > А вот в Perl close(STDOUT) в mod_perl/fast-cgi вообще не имеет смысла, а fork работает и в cgi, и в fast-cgi, и в mod_perl.
> >
> >> > При этом очевидно, что форк catalyst это ужжасно долго,
> >>
> >> fork под Unix - это всегда очень быстро, программа не копируется, а
> >> используется COW. Например, Apache+mod_perl использует COW, а в данном
> >> случае размер процесса может быть весьма большим.
> >
> > Вы не забыли что речь идет не о helloworld а о реальном продакшеновом приложении под catalyst?
> > Там может быть например презагрузка кучи либ и также прекеширование данных на старте.
> > Ну допустим оно даже форкается тупым копированием памяти, но это все равно сожрет кучу ОЗУ
>
> Как я написал раньше, fork - это не копирование. Память помечается как
> используемая несколькими процессами. fork был специально так
> оптимизирован. В частности, system() работает через fork().
>
Тут вот, можно поподробнее. Я думал всегда, что идёт всё же копирование скопа. И, для threads, в отличии от классического fork можно указать совместно используемые переменные (= память). Если форк тупо помечает память, то при изменении переменных, это бы видели остальные чилды. Что как бэ не так. Значит ссылки на переменные - откопированны, а не просто помеченны.
> > Так, по опыту, в реальной жизни, приложение на catalyst может стартовать десятки секунд.
>
> Запускаться и делать fork - принципиально разные вещи.
>
>
Вопрос есть ещё: сгенерить UUID для подтверждения, прописать его в базе, сформировать письмецо и скинуть его на локальный postfix (ну или что там) - это даже не нагрузка. И времени это не занимает. В чём оптимизация-то процесса регистрации?
Может нужно не Catalyst костылить, а посмотреть в чём реальный тормоз у вас при регистрации?
More information about the Kiev-pm
mailing list