Ограничение процессорной нагрузки (более жесткое)
Материал из 1GbWiki.
Версия 08:58, 17 мая 2011 (править) Rekby (Обсуждение | вклад) (Новая: Этот ограничитель - модификация стандартного ограничителя для ...) ← К предыдущему изменению |
Версия 05:44, 26 сентября 2011 (править) (отменить) Rekby (Обсуждение | вклад) К следующему изменению → |
||
Строка 15: | Строка 15: | ||
=== Отличия от стандартного ограничителя === | === Отличия от стандартного ограничителя === | ||
Стандартный ограничитель вызывается перед обработкой каждого вашего php-файла и принять решение о блокировке может только когда обработка php уже началась и на это затрачено процессорное время сервера. Этот ограничитель вызывается 1 раз в минуту независимо от посещения вашего сайта и анализирует текущую нагрузку. Если она превышает параметры, то в .htaccess добавляются правила, запрещающие обращения к сайту на уровне apache, т.е. для понимания того что нужно блокировать запрос уходит значительно меньше ресурсов. Пользователям в этом случае будет отдаваться статическая страница с вашим сообщением, за счет этого ограничитель может сглаживать более мощные всплески нагрузки. | Стандартный ограничитель вызывается перед обработкой каждого вашего php-файла и принять решение о блокировке может только когда обработка php уже началась и на это затрачено процессорное время сервера. Этот ограничитель вызывается 1 раз в минуту независимо от посещения вашего сайта и анализирует текущую нагрузку. Если она превышает параметры, то в .htaccess добавляются правила, запрещающие обращения к сайту на уровне apache, т.е. для понимания того что нужно блокировать запрос уходит значительно меньше ресурсов. Пользователям в этом случае будет отдаваться статическая страница с вашим сообщением, за счет этого ограничитель может сглаживать более мощные всплески нагрузки. | ||
+ | |||
+ | [[Категория:Серверная нагрузка]] |
Версия 05:44, 26 сентября 2011
Этот ограничитель - модификация стандартного ограничителя для работы со скачками нагрузки средней величины.
Предварительная информация
Работает только на 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, т.е. для понимания того что нужно блокировать запрос уходит значительно меньше ресурсов. Пользователям в этом случае будет отдаваться статическая страница с вашим сообщением, за счет этого ограничитель может сглаживать более мощные всплески нагрузки.