-
Notifications
You must be signed in to change notification settings - Fork 74
Naemon and Adagios Install Guide
hakong edited this page Mar 2, 2016
·
57 revisions
This document explains how to install Adagios and Naemon on CentOS 7 or Red Hat Enterprise Linux 7 x86_64.
If you find any errors in these docs, please be so kind to either update the wiki or file an issue in the issue tracker.
# If you don't know how to configure SElinux, put it in permissive mode:
sed -i "s/SELINUX=enforcing/SELINUX=permissive/" /etc/sysconfig/selinux
setenforce 0
# First install the opensource.is and consol labs repositories
rpm -ihv http://opensource.is/repo/ok-release.rpm
rpm -Uvh https://labs.consol.de/repo/stable/rhel7/x86_64/labs-consol-stable.rhel7.noarch.rpm
yum update -y ok-release
# Redhat/Centos users need to install the epel repositories (fedora users skip this step)
yum install -y epel-release
# Install naemon, adagios and other needed packages
yum --enablerepo=ok-testing install -y mk-livestatus naemon git adagios okconfig acl pnp4nagios python-setuptools
# Workaround until OK update their repo
rpm -Uvh https://github.com/opinkerfi/adagios/releases/download/adagios-1.6.3-1/adagios-1.6.3-1.el7.centos.noarch.rpm
wget https://raw.githubusercontent.com/opinkerfi/okconfig/master/usr/share/okconfig/client/linux/install_okagent.sh -O /usr/share/okconfig/client/linux/install_okagent.sh
chmod +x /usr/share/okconfig/client/linux/install_okagent.sh
cat << EOF > /etc/yum.repos.d/ok-rhel6.repo
[ok-rhel6]
name=Opin Kerfi Public Repo - \$basearch
baseurl=http://opensource.is/repo/rhel6/\$basearch
failovermethod=priority
enabled=1
gpgcheck=0
[ok-testing-rhel6]
name=Opin Kerfi Public Repo - Testing - \$basearch
baseurl=http://opensource.is/repo/testing/rhel6/\$basearch
failovermethod=priority
enabled=0
gpgcheck=0
EOF
# Now all the packages have been installed, and we need to do a little bit of
# configuration before we start doing awesome monitoring
# Lets make sure adagios can write to naemon configuration files, and that
# it is a valid git repo so we have audit trail
cd /etc/naemon/
git init
git add .
git commit -a -m "Initial commit"
# Make sure naemon group will always have write access to the configuration files:
chown -R naemon:naemon /etc/naemon /etc/adagios /var/lib/adagios /var/lib/pnp4nagios /var/log/pnp4nagios
# ACL group permissions need g+rwx
chmod g+rwx -R /etc/naemon /etc/adagios /var/lib/adagios /var/lib/pnp4nagios /var/log/pnp4nagios
setfacl -R -m group:naemon:rwx -m d:group:naemon:rwx /etc/naemon/ /etc/adagios /var/lib/adagios /var/lib/pnp4nagios /var/log/pnp4nagios
# Make sure nagios doesn't interfere
mkdir /etc/nagios/disabled
mv /etc/nagios/{nagios,cgi}.cfg /etc/nagios/disabled/
# Make objects created by adagios go to /etc/naemon/adagios
mkdir -p /etc/naemon/adagios
pynag config --append cfg_dir=/etc/naemon/adagios
# Make adagios naemon aware
sed -i '
s|/etc/nagios/passwd|/etc/naemon/htpasswd|g
s|user=nagios|user=naemon|g
s|group=nagios|group=naemon|g' /etc/httpd/conf.d/adagios.conf
sed -i '
s|/etc/nagios/nagios.cfg|/etc/naemon/naemon.cfg|g
s|nagios_url = "/nagios|nagios_url = "/naemon|g
s|/etc/nagios/adagios/|/etc/naemon/adagios/|g
s|/etc/init.d/nagios|/etc/init.d/naemon|g
s|nagios_service = "nagios"|nagios_service = "naemon"|g
s|livestatus_path = None|livestatus_path = "/var/cache/naemon/live"|g
s|/usr/sbin/nagios|/usr/bin/naemon|g' /etc/adagios/adagios.conf
# Make okconfig naemon aware
sed -i '
s|/etc/nagios/nagios.cfg|/etc/naemon/naemon.cfg|g
s|/etc/nagios/okconfig/|/etc/naemon/okconfig/|g
s|/etc/nagios/okconfig/examples|/etc/naemon/okconfig/examples|g' /etc/okconfig.conf
okconfig init
# Add naemon to apache group so it has permissions to pnp4nagios's session files
usermod -G apache naemon
# Allow Adagios to control the service
sed -i '
s|nagios|naemon|g
s|/usr/sbin/naemon|/usr/bin/naemon|g' /etc/sudoers.d/adagios
# Make naemon use nagios plugins, more people are doing it like that.
sed -i 's|/usr/lib64/naemon/plugins|/usr/lib64/nagios/plugins|g' /etc/naemon/resource.cfg
# Make naemon work with pnp4nagios
# todo
# We need to restart both apache and naemon so new changes take effect
systemctl enable naemon
systemctl enable httpd
systemctl enable npcd
systemctl start naemon
systemctl start httpd
systemctl start npcd
# Allow connections through the firewall on port 80 and 443
firewall-cmd --add-service=https --permanent
firewall-cmd --add-service=http --permanent
firewall-cmd --reload
# Optional: Install all available plugins from the rhel6 repository since OK haven't updated their rhel7 repo:
yum install nagios-okplugin-* --skip-broken --enablerepo=ok-rhel6 --enablerepo=ok-testing-rhel6