![NGINX: Как бороться с явно фиктивным трафиком на сервере, который выполняет безусловное полное перенаправление?](https://rvso.com/image/717735/NGINX%3A%20%D0%9A%D0%B0%D0%BA%20%D0%B1%D0%BE%D1%80%D0%BE%D1%82%D1%8C%D1%81%D1%8F%20%D1%81%20%D1%8F%D0%B2%D0%BD%D0%BE%20%D1%84%D0%B8%D0%BA%D1%82%D0%B8%D0%B2%D0%BD%D1%8B%D0%BC%20%D1%82%D1%80%D0%B0%D1%84%D0%B8%D0%BA%D0%BE%D0%BC%20%D0%BD%D0%B0%20%D1%81%D0%B5%D1%80%D0%B2%D0%B5%D1%80%D0%B5%2C%20%D0%BA%D0%BE%D1%82%D0%BE%D1%80%D1%8B%D0%B9%20%D0%B2%D1%8B%D0%BF%D0%BE%D0%BB%D0%BD%D1%8F%D0%B5%D1%82%20%D0%B1%D0%B5%D0%B7%D1%83%D1%81%D0%BB%D0%BE%D0%B2%D0%BD%D0%BE%D0%B5%20%D0%BF%D0%BE%D0%BB%D0%BD%D0%BE%D0%B5%20%D0%BF%D0%B5%D1%80%D0%B5%D0%BD%D0%B0%D0%BF%D1%80%D0%B0%D0%B2%D0%BB%D0%B5%D0%BD%D0%B8%D0%B5%3F.png)
Я столкнулся с довольно интересной проблемой, пытаясь настроить NGinx. Я запустил небольшой веб-сервер, который обслуживает все по HTTPS с NGinx 1.13.8. Как это типично для такой конфигурации, он также прослушивает порт 80 и выполняет полное перенаправление для всех запросов на порт 443 с тем же URI, используя следующий фрагмент конфигурации для достижения этого:
location / {
return 301 https://$server_name$request_uri;
}
Это само по себе отлично сработало для того, для чего мне это было нужно. Однако я начал получать явно фиктивный и легко идентифицируемый трафик (случайные периоды около 5 минут, когда я получаю тысячу новых подключений с, казалось бы, случайных IP-адресов, все с общим префиксом в заголовке User-Agent, все делают абсолютно одинаковый запрос ( HEAD / HTTP/1.1
), все оставляют соединение открытым до истечения времени ожидания и все никогда не следуют перенаправлению).
В идеале я бы хотел просто закрыть эти соединения, как только они будут идентифицированы, чтобы минимизировать количество ресурсов, которые они тратят впустую. В настоящее время я придумал этот измененный фрагмент конфигурации, чтобы сделать это:
location / {
return 301 https://$server_name$request_uri;
}
location = / {
if ($method = "HEAD") {
set $drop M;
}
if ($http_user_agent ~* "Dalvik/2.1.0 (Linux U ") {
set $drop "U${drop}";
}
if ($drop = "UM") {
return 444;
}
}
Однако это, похоже, не работает (поскольку журналы по-прежнему показывают эти пики трафика, полностью возвращающие 301). Я также пробовал менее конкретное соответствие (просто общие соответствия по заголовку User-Agent или методу) внутри первого блока местоположения, и это, похоже, тоже не работает.
Итак, у меня два вопроса:
- Почему это не работает?
- Есть ли лучший способ обработки этого трафика, который потенциально не требует глубокой проверки пакетов в брандмауэре?