Re: Nginx подвисает при ротации лога
Maxim Dounin
mdounin на mdounin.ru
Вт Мар 1 13:59:34 MSK 2011
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