Ограничение процессорной нагрузки (более жесткое)
Материал из 1GbWiki.
Текущая версия
Этот ограничитель - модификация стандартного ограничителя для работы со скачками нагрузки средней величины.
[править] Предварительная информация
- Работает только на Unix-сайтах, для настройки потребуется подключение по ssh настрока crontab.
- Для работы этого ограничителя нужно предварительно настроить обычный через личный кабинет.
[править] Настройка
Для его настройки нужно:
- скачать и распаковать в корень FTP-папки файл http://rekby.1gb.ru/scripts/auto_deny.php.gz
- в начале файла прописать все домены, работу которых нужно контролировать (поддомены www. учитываются автоматически, их писать не нужно), домены .рф нужно записывать в punycode-форме.
- переместить ваш .htaccess из папки http в домашнюю папку пользователя и переименовать в htaccess_template
- добавить в unix_cron ежеминутное задание на выполнение скрипта ограничителя вида
- создать в корне папки http файл block.html - он будет показываться блокированным посетителям.
* * * * * /usr/local/bin/php -f /home/virtwww/w_blablabla_32423/auto_deny.php
[править] Отличия от стандартного ограничителя
Стандартный ограничитель вызывается перед обработкой каждого вашего php-файла и принять решение о блокировке может только когда обработка php уже началась и на это затрачено процессорное время сервера. Этот ограничитель вызывается 1 раз в минуту независимо от посещения вашего сайта и анализирует текущую нагрузку. Если она превышает параметры, то в .htaccess добавляются правила, запрещающие обращения к сайту на уровне apache, т.е. для понимания того что нужно блокировать запрос уходит значительно меньше ресурсов. Пользователям в этом случае будет отдаваться статическая страница с вашим сообщением, за счет этого ограничитель может сглаживать более мощные всплески нагрузки.