Я включил apache_плагины на узле munin:
ln -sv /usr/share/munin/plugins/apache_* /etc/munin/plugins/
После перезапуска узла service munin-node restartвот ошибки, которые я получаю:
$ munin-node-configure --suggest 2>/dev/null | grep "apache\|Plugin\|------"
Plugin | Used | Suggestions
------ | ---- | -----------
apache_accesses | yes | no [apache server-status not found. check if mod_status is enabled]
apache_processes | yes | no [apache server-status not found. check if mod_status is enabled]
apache_volume | yes | no [apache server-status not found. check if mod_status is enabled]
Однако mod_statusуже включен:
$ a2enmod status
Module status already enabled
И перезапуск apache не имеет значения.
Если я попытаюсь запустить плагины вручную, вот что я получаю (я читал, что получение U - плохая новость, так что, по крайней мере, это соответствует).
$ munin-run apache_accesses --debug
# Processing plugin configuration from /etc/munin/plugin-conf.d/munin-node
# Set /rgid/ruid/egid/euid/ to /110/65534/110 110 /65534/
# Setting up environment
# About to run '/etc/munin/plugins/apache_accesses'
accesses80.value U
$ munin-run apache_processes --debug
# Processing plugin configuration from /etc/munin/plugin-conf.d/munin-node
# Set /rgid/ruid/egid/euid/ to /110/65534/110 110 /65534/
# Setting up environment
# About to run '/etc/munin/plugins/apache_processes'
busy80.value U
idle80.value U
free80.value U
$ munin-run apache_volume --debug
# Processing plugin configuration from /etc/munin/plugin-conf.d/munin-node
# Set /rgid/ruid/egid/euid/ to /110/65534/110 110 /65534/
# Setting up environment
# About to run '/etc/munin/plugins/apache_volume'
volume80.value U
Кто-нибудь знает, почему я все еще получаю server-status not foundсообщение и как я могу от него избавиться?
Обновленный ответ 1
Предложение Шейна было правильным относительно настройки обработчика запросов с помощью Locationи SetHandlerна сайте apache. Для получения дополнительной информации, mod_statusпожалуйста, обратитесь к этой странице
Я мог убедиться, что muninэто эффективно делает соответствующие запросы, посмотрев, /var/log/apache2/access.logгде я получаю это:
127.0.0.1 - - [10/Nov/2011:07:24:15 +0000] "GET /server-status?auto HTTP/1.1" 404 7774 "-" "libwww-perl/5.834
В моем случае настройки Locationбыло недостаточно, так как я управляю Drupalсайтом, а в .htaccessсочетании с mod_rewriteпереписываем запросы. Чтобы это исправить, мне пришлось добавить следующую строку в мой.htaccess
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_URI} !=/favicon.ico
RewriteCond %{REQUEST_URI} !=/server-status # <= added this line
RewriteRule ^(.*)$ index.php?q=$1 [L,QSA]
Обратите внимание, что это не представляет проблемы безопасности, так как доступ к нему /server-statusограничен на 127.0.0.1сайте apache.
Обновленный ответ 2
Похоже, что добавление Locationна сайт apache не было необходимости, поскольку это уже определено в /etc/apache2/mods-enabled/status.conf. Кстати, если вы хотите добавить ExtendedStatus Onдирективу, это в том файле, что вы должны сделать это.
mod_rewriteработу (см. Обновленный вопрос с ответом)