ПРОЕКТЫ 


  АРХИВ 


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: Nginx подвисает при ротаци и лога



Hello!

On Tue, Mar 01, 2011 at 05:31:22AM -0500, el wrote:

> Сейчас еще раз прошерстили конфиги и
> скрипты.
> Лог крутится через newsyslog, в конфиге в
> обработке последней строчки указан
> pid-файл - т.е. в этот момент nginx должен
> получить от него сигнал HUP. Далее в
> скрипте логи переименовываются,
> зипуются и еще раз nginx-у отправляется
> сигнал HUP.
> Достаточно долгое время схема работала
> без сбоев.
> Есть гипотеза, что из-за высокой
> нагрузки и задержки ответа бекенда nginx
> подвисает из-за двух HUP-ов. Может быть по
> другой причине...

По сигналу HUP nginx будет перечитывать конфигурацию и запускать 
новые рабочие процессы с новой конфигурацией, при этом старые 
завершатся только тогда, когда все обслуживаемые ими запросы 
отработают.  Соответственно если HUP посылают чаще, чем старые 
рабочие процессы успевают завершаться - рано или поздно в системе 
кончится память и/или другие ресурсы, последствия могут быть 
любые.

Для переоткрытия логов nginx'у надо посылать сигнал USR1.  
Достаточная схема для вращения логов - переименовать лог, послать 
nginx'у USR1, подождать пару секунд (пока nginx его закроет).  
Дальше с логом можно делать что угодно.

Maxim Dounin

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


 




Copyright © Lexa Software, 1996-2009.