How to Configure LDAP Authentication for Nagios on CentOS 5.5

Share this Article :

This article assume that you already installed the nagios server on LAMP CentOS server and also installed 389 directory server. On the previous tutorial, the user that allowed to manage nagios is nagiosadmin which has been created using htpasswd. In this article, i will show you on how configure LDAP authentication for Nagios on CentOS 5.5.

Prerequisites
How to Install Apache Httpd Web Server on Linuxrel=”nofollow”
How to Install 389 Directory Server on CentOS/RHEL

Also Read :   How to Configure EPEL Repository on CentOS 6.3

1. Configure nagios.conf and change it to your LDAP environment. Assume the following info is valid on LDAP server:

    Server ip = 192.168.2.5
    Suffix = dc=intranet, dc=local
    LDAP user : user1 ( most of the time, this user is sytem administrator)
    
    [[email protected] ~]# vi /etc/httpd/conf.d/nagios.conf
    
    ScriptAlias /nagios/cgi-bin "/usr/lib/nagios/cgi"
    
    <Directory "/usr/lib/nagios/cgi">
       Options ExecCGI
       AllowOverride None
       Order allow,deny
       Allow from all
       AuthBasicProvider ldap
       AuthType Basic
       AuthzLDAPAuthoritative on
       AuthName " LDAP Authentication for Nagios Monitoring"
       AuthLDAPURL "ldap://192.168.2.5:389/DC=intranet,DC=local?uid?sub?(objectClass=*)" NONE
       Require user
    </Directory>
    
    Alias /nagios "/usr/share/nagios"
    
    <Directory "/usr/share/nagios">
       Options None
       AllowOverride None
       Order allow,deny
       Allow from all
       AuthBasicProvider ldap
       AuthType Basic
       AuthzLDAPAuthoritative on
       AuthName " LDAP Authentication for Nagios Monitoring"
       AuthLDAPURL "ldap://192.168.2.5:389/DC=intranet,DC=local?uid?sub?(objectClass=*)" NONE
       Require user
    </Directory>
    

2. Replace all of the “nagiosadmin” entries with “*” in /etc/nagios/cgi.cfg. This is to prevent the error message in CGI authentication.

    It appears as though you do not have permission to view information for any of the hosts you requested...
    
    If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI
    and check the authorization options in your CGI configuration file.
    
    [[email protected] ~]# grep "nagiosadmin" /etc/nagios/cgi.cfg | grep -v "#"
    
    authorized_for_system_information=nagiosadmin
    authorized_for_configuration_information=nagiosadmin
    authorized_for_system_commands=nagiosadmin
    authorized_for_all_services=nagiosadmin
    authorized_for_all_hosts=nagiosadmin
    authorized_for_all_service_commands=nagiosadmin
    authorized_for_all_host_commands=nagiosadmin
    
    [[email protected] ~]# vi /etc/httpd/conf.d/nagios.conf
    

Replace nagiosadmin to * as below:

    authorized_for_system_information=*
    authorized_for_configuration_information=*
    authorized_for_system_commands=*
    authorized_for_all_services=*
    authorized_for_all_hosts=*
    authorized_for_all_service_commands=*
    authorized_for_all_host_commands=*
    
    [[email protected] ~]# grep "*" /etc/nagios/cgi.cfg | grep -v "#"
    authorized_for_system_information=*
    authorized_for_configuration_information=*
    authorized_for_system_commands=*
    authorized_for_all_services=*
    authorized_for_all_hosts=*
    authorized_for_all_service_commands=*
    authorized_for_all_host_commands=*
    

3. Restart the nagios service

    [[email protected] ~]# /etc/init.d/nagios restart
    Stopping nagios:                                           [  OK  ]
    Starting nagios:                                           [  OK  ]
    

4. Restart apache server

    [[email protected] ~]# /etc/init.d/httpd restart
    Stopping httpd:                                            [  OK  ]
    Starting httpd:                                            [  OK  ]
    


2 Comments

  1. Srinivasa Nallapati
  2. Amir

Leave a Reply