Welcome! Log In Create A New Profile

Advanced

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

February 13, 2024 02:11AM
Gena Makhomed Wrote:
-------------------------------------------------------
> On 12.02.2024 11:53, Evgeniy Berdnikov wrote:
>
> >> Ротация логов делается с помощью программы logrotate, которая
> делает
> >> ротацию только по времени и никак не смотрит на количество
> свободного
> >> места на диске и на размер лог-файла.
> >
> > Насчёт размера файла утверждение неверное: в конфиге logrotate
> можно
> > указать директиву "size", которая будет означать предельный
> размер
> > лог-файла, по достижении которого запускается ротация. Другое
> дело, что
> > риалтаймовского триггера на достижение предельного размера файла
> нет.
> > А он мог бы быть в nginx-е, среди опций access_log и error_log.
>
> Я немного не точно выразился. Интересует запуск ротации логов
> не по размеру одного какого-то лог-файла, а по суммарному
> размеру всего каталога /var/log/nginx/
>
> Потому что даже если выставить лимит size 1G на один лог-файл -
> не всегда понятно, сколько именно места на диске будет занимать
> каталог /var/log/nginx/ rotate 52 задает количество ротаций
> только одного одного файла. А размер каталога /var/log/nginx/
> зависит от того, сколько там будет лог-файлов - всего два,
> access.log и error.log или несколько сотен, или несколько тысяч.
>
> Вообще, в идеале - хотелось бы иметь возможность и значение rotate
> не статически задавать в конфиге, а делать динамически вычисляемым,
> по определенной формуле, в зависимости от размера каталога
> /var/log/nginx/ и/или количества свободного места на диске
> и других параметров.
>
> Наверное, самый оптимальный вариант решения всех этих проблем
> - это сделать демона logrotated, который будет следить
> за количеством занятого и/или свободного места на разделе /var
> и в результате - если необходимо делать принудительную
> ротацию логов, - будет сам генерировать временный файл
> конфигурации, например, /run/logrotated/nginx-logrotate.conf
> и потом уже запускать утилиту /usr/sbin/logrotate
> для выполнения работы по ротации логов, примерно так:
>
> /usr/sbin/logrotate --force /run/logrotated/nginx-logrotate.conf
>
> то есть, когда DDoS-атак нет - тогда демон logrotated просто висит
> в фоне, время от времени проверяя состояние и ничего не делает,
> потому что ни один триггер не срабатывает. И тогда всю работу
> по ротации логов nginx делает сама программа logrotate,
> запускаемая по крону раз в сутки. А когда происходит DDoS-атака,
> тогда logrotated обнаруживает чрезмерное использование места
> на диске логами nginx и начинает делать принудительную ротацию
> логов, не допуская исчерпания свободного места на диске
> DDoS-атакой и наступления ситуации отказа в обслуживании.
>
> >> Это может быть полезно в случае DDoS-атак, чтобы не не было
> >> таких неожиданных ситуаций, что место на сервере внезапно
> закончилось
>
> > Для DoS-атак как раз и полезно разделение обязанностей между
> рабочим
> > процессом сервиса и процессом-писателем логов.
>
> Та система, которая есть сейчас - она близка к идеальной,
> когда каждая утилита делает только свою работу, но делает
> ее очень хорошо - nginx только обрабатывает запосы клиентов,
> а logrotate - занимается только задачей ротации логов.
>
> > Я уже упоминал здесь
> > сквидовский logfile-daemon, это один из вариантов, как можно
> обезопасить
> > рабочий процесс от ступора.
>
> У nginx нет ступора рабочих процессов том случае, когда закончилось
> свободное место на диске. Он даже дополнительно делает паузу в одну
> секунду, чтобы на FreeBSD все не тормозило, когда нет свободного
> места на диске. То есть, со стороны nginx - вообще никаких проблем.
>
> https://github.com/nginx/nginx/blob/master/src/http/modules/ngx_http_l
> og_module.c#L288
>
> Проблемы начинаются у остального софта, например, MySQL прекращает
> нормально работать, потому что ничего не может записать в базу
> данных,
> когда на диске 0 байт свободного места и php-fpm начинает возвращать
> 5xx статус - то есть, в результате и получается denial of service.
>
> > А костыли в виде логов в оперативной памяти, logrotate и
> питоновских
> > скриптов можно, конечно, нагородить. Но в современной ситуации, я
> думаю,
> > проще сделать триггер, который по обнаружении катастрофической
> нехватки
> > места для логов просто отключит логгирование в nginx-e.
>
> Когда свободного места на диске нет - то nginx туда, естественно,
> ничего и не пишет, когда свободное место появляется - процесс записи
> логов автоматически продолжается, тут ничего настраивать не нужно.
>
> Единственная проблема которая есть в такой сиутации - перестают
> работать
> POST-запросы, если в каталоге client_body_temp_path ноль байт
> свободного
> места, но все остальные типы запросов в такой ситуации nginx
> продолжает
> нормально обрабатывать. И теряется возможность записи информации в
> логи.
>
> Все остальное - вроде бы работает нормально, когда 0 байт
> свободного места на диске - но я очень детально это не проверял.
>
> >> не делать автоматической защиты от DDoS через исчерпание
> свободного
> >> места на диске - потому что идеологически правильно чтобы эту
> проблему
> >> вручную устранял системный администратор, потому что старые логи
> важны
> >> и нужны.
>
> > Работоспособность web-сервиса, как правило, намного важнее
> логгирования.

>
> Тогда почему в операционной системе logrotate запускается по крону
> только раз в сутки и там нет вообще никакой защиты на этом уровне
> от исчерпания свободного места на диске? Это просто никому не нужно
> или же причина в том, что неправильно чтобы система автоматически
> поддерживала себя в рабочем состоянии и не переходила в состояние
> denial of service когда на какой-то сайт приходит DDoS-атака?
>
> Не могу понять причину, почему не существует демона logrotated,
> ведь если бы это было нужно не только мне, а и кому-то еще - его
> бы уже давным-давно кто-то другой придумал бы и написал, и такой
> демон был бы или в отдельном пакете или даже в составе logrotate
> в составе каждого дистрибутива Linux.
>
Мое мнение:
Ваш подход описан в парадигме "все в одном".
Т.е. всё необходимое крутится на одной машине и взаимно влияют друг на друга по CPU/RAM/IOPS и т.д , а даже в средних проектах это далеко не всегда так.

Прокси-фронт отдельно, и зачастую не один, а несколько.

БД -- отдельно, и исчерпание места на прокси-фронте ее вообще не касается,

логи при необходимости сливаются в архив и так же не хранятся на прокси-фронте или где-либо еще в сколь-нибудь существенном объёме.

бекэнды зачастую вообще контейнеры в динамике от нагрузки.

Как только вы растаскиваете все необходимые сервисы по разным кластерам одни проблемы отпадают, другие появляются.
И проблема logrotate теряет актуальность.
Subject Author Posted

Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru January 17, 2024 06:50AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин January 17, 2024 07:34AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

anatoliy.melnik@showjet.ru January 18, 2024 02:13AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Maxim Dounin January 17, 2024 12:04PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

anatoliy.melnik@showjet.ru January 18, 2024 02:57AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru January 18, 2024 11:14AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov January 18, 2024 11:46AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Pavel Yakovlev January 19, 2024 03:50AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru January 18, 2024 11:16AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Maxim Dounin January 18, 2024 02:32PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru January 18, 2024 02:12PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov January 18, 2024 03:30PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин January 18, 2024 04:56PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru January 22, 2024 04:12AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

hery2 January 25, 2024 09:18AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 05, 2024 06:42AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov February 05, 2024 07:06AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 05, 2024 07:18AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 05, 2024 08:22AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 05, 2024 02:58PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 05, 2024 04:12PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov February 05, 2024 04:22PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 05, 2024 05:58PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Maxim Dounin February 05, 2024 05:26PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 09, 2024 06:36AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 09, 2024 07:52AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 11, 2024 01:34PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 11, 2024 02:38PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 11, 2024 02:40PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov February 11, 2024 04:04PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 11, 2024 06:12PM

Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

Gena Makhomed February 11, 2024 06:16PM

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

Evgeniy Berdnikov February 12, 2024 04:56AM

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

Gena Makhomed February 12, 2024 09:22PM

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

Gena Makhomed February 12, 2024 11:46PM

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

anatoliy.melnik@showjet.ru February 13, 2024 06:18AM

Re: Как лучше всего сделать защиту от denial of service при исчерпании свободного места на диске большими по объему лог-файлами nginx?

anatoliy.melnik@showjet.ru February 13, 2024 02:11AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 12, 2024 05:32AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 12, 2024 10:32PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 13, 2024 04:40AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Илья Шипицин February 13, 2024 06:08AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

anatoliy.melnik@showjet.ru February 14, 2024 06:54AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 13, 2024 10:16PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 14, 2024 06:32AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Evgeniy Berdnikov February 14, 2024 12:34PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 14, 2024 10:06PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 14, 2024 05:00PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 15, 2024 05:50AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 15, 2024 03:22PM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 19, 2024 09:02AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 20, 2024 12:50AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Anatoliy Melnik via nginx-ru February 21, 2024 07:56AM

Re: Тест nginx -- сколько сообщений в log syslog без потерь?

Gena Makhomed February 21, 2024 01:30PM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 329
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 500 on July 15, 2024
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready