apache server-status não encontrado. verifique se o mod_status está ativado

8

Eu ativei os plug-ins apache_ em um nó munin:
ln -sv /usr/share/munin/plugins/apache_* /etc/munin/plugins/

Depois de reiniciar o nó com service munin-node restart , aqui estão os erros que estou recebendo:

$ 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]

No entanto, mod_status já está ativado:

$ a2enmod status
Module status already enabled

E reiniciar o apache não faz diferença.

Se eu tentar rodar os plugins manualmente, aqui é o que eu recebo (eu li que conseguir U é má notícia, então pelo menos isso é consistente).

$ 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

Alguém sabe por que ainda estou recebendo a mensagem server-status not found e como posso me livrar dela?

Resposta atualizada 1

A sugestão de Shane estava correta sobre a configuração de um manipulador de solicitações usando Location e SetHandler no site do apache. Para mais informações sobre mod_status , consulte esta página

Eu pude verificar que munin estava efetivamente fazendo as solicitações apropriadas olhando para /var/log/apache2/access.log onde eu estava recebendo isso:

127.0.0.1 - - [10/Nov/2011:07:24:15 +0000] "GET /server-status?auto HTTP/1.1" 404 7774 "-" "libwww-perl/5.834

No meu caso, a configuração de Location não foi suficiente, pois estou executando um site Drupal e o .htaccess combinado com mod_rewrite estava reescrevendo as solicitações. Para corrigi-lo, eu tive que adicionar a seguinte linha ao meu .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]

Observe que isso não representa um problema de segurança, pois o acesso a /server-status está restrito a 127.0.0.1 no site do apache.

Resposta atualizada 2

Parece que não foi necessário adicionar o Location ao site do apache, já que isso já está definido em /etc/apache2/mods-enabled/status.conf . Btw, se você quiser adicionar a diretiva ExtendedStatus On , é nesse arquivo que você deve fazer isso.

    
por Max 08.11.2011 / 13:02

6 respostas

5

Parece que está tentando fazer solicitações ao módulo de status. Você tem uma configuração adequada para o local do status em VirtualHost ? Algo parecido com isto:

<Location /server-status>
    SetHandler server-status
    Order deny,allow
    Deny from all
    Allow from 127.0.0.1
</Location>
    
por 08.11.2011 / 19:58
3

Eu descobri que podia correr

$ wget http://localhost/server-status?auto

mas não

$ wget http://127.0.0.1/server-status?auto

O primeiro está atingindo o servidor padrão, o segundo, um servidor virtual.

Então eu adicionei explicitamente uma seção do apache a /etc/munin/plugin-conf.d/munin-node

[apache_*]
env.url   http://localhost:%d/server-status?auto
env.ports 80

e tenho meus gráficos munin apache.

    
por 23.05.2012 / 16:32
2

Eu encontrei a solução do Many Ayromlou neste site :

The problem is that these .htaccess rules in wordpress take over server-info and server-status urls activated in apache’s config and return a page not found error. I came across numerous sites that suggested adding a rule like:

  RewriteCond %{REQUEST_URI} !=/server-status

This didn't work for me. I'm not sure if the multisite version of wordpress (which I'm using) is causing this. The rule that worked beautifully is the following:

  RewriteRule ^(server-info|server-status) - [L]

This rule stops the rewrite engine whenever server-info or server-status is parsed as part of the URL.

    
por 12.05.2012 / 11:01
1

mod_status embutido no servidor da web Apache para obter o status do servidor de um navegador da web. Com este módulo, podemos descobrir com facilidade o desempenho do servidor. Todos os relatórios são gerados em um formato html.

Passo 1. Verifique se o módulo de status está ativado ou não apache2ctl -M ou ls / etc / apache2 / sites-enabled

Passo 2. Se não estiver ativado, ative-o pelo comando

sudo a2enmod status

step3. Configurar acesso,

Abra o /etc/apache2/mods-enabled/status.conf e comente as linhas,

        #<Location /server-status>
        #    SetHandler server-status
        #    Require local
        #Require ip 192.0.2.0/24
        #</Location>

Adicione a seguinte linha,

        <Location /server-status>
        SetHandler server-status
        Order deny,allow
        Allow from all
        </Location>

Podemos restringir o acesso do status do servidor para determinados IPs nesta configuração, editando Permitir de our_public_ipaddress em vez de Allow de todos

Salve o arquivo status.conf.

Passo 4. Reinicie o apache pelo comando

/etc/init.d/apache2 restart

Verifique a página de status do servidor no navegador

link

Espero que isso seja útil.

    
por 16.02.2015 / 09:55
0

Eu estava tendo o mesmo problema. Aqui estão mais alguns passos de diagnóstico. Tente fazer

munin-run apache_processes autoconf

Essa é uma maneira mais direta de ver o mesmo erro " no (sem status de servidor do apache nas portas 80) "

Agora tente fazer

wget http://127.0.0.1/server-status?auto

Para mim, isso está dando 403 Forbidden .

Eu também estava vendo 'cliente negado pela configuração do servidor: / var / www / server-status' no meu log de erro principal do apache

Você está recebendo o mesmo?

Para mim, na verdade, a resposta de Shane Madden resolveu isso.

    
por 08.11.2011 / 15:29
0

Se / server-status for proibido somente a partir de 127.0.0.1, você poderá criar a configuração do VirtualHost para 127.0.0.1 com o seguinte conteúdo:

<VirtualHost *:80>
    ServerAdmin [email protected]
    ServerName 127.0.0.1
    DocumentRoot /var/www
    <Directory />
            Options FollowSymLinks
            AllowOverride All
    </Directory>
    <Directory /var/www>
      Options +FollowSymLinks
      AllowOverride None
      order allow,deny
      allow from all
    </Directory>
</VirtualHost>

Aqui está

    
por 02.12.2014 / 23:20