用SHELL脚本自动化安装Nagios服务器端和客户端的

公司的一个项目网站,上线几天就由于磁盘暴满而出了问题,因为其服务器都集中在某一IDC机房内,因此考虑部署套Nagios监控报警系统,考虑到其它项目网站可能有相似需求,因此将其安装过程整理成脚本,方便之后的工做。 Nagios服务器自动安装脚本,以下所示(此脚本在Centos5.5|5.6|5.8 x86_64下经过):

yum -y install httpd gcc gcc-c++ glibc glibc-common gd gd-devel
useradd nagios
groupadd nagcmd
usermod    -G nagcmd nagios
usermod    -G nagcmd apache
cd /usr/local/src
wget http://nchc.dl.sourceforge.net/sourceforge/nagios/nagios-3.0.6.tar.gz
wget http://nchc.dl.sourceforge.net/sourceforge/nagiosplug/nagios-plugins-1.4.13.tar.gz
wget http://prdownloads.sourceforge.net/sourceforge/nagios/nrpe-2.13.tar.gz
tar zxvf nagios-3.0.6.tar.gz
cd nagios-3.0.6
./configure --with-command-group=nagcmd --prefix=/usr/local/nagios
make all
make install
make install-init
make install-config
make install-commandmode
make install-webconf
cd ../
tar zxvf nagios-plugins-1.4.13.tar.gz
cd nagios-plugins-1.4.13
./configure --prefix=/usr/local/nagios --with-nagios-user=nagios --with-nagios-group=nagios
make && make install
cd ../
tar zxvf nrpe-2.13.tar.gz
cd nrpe-2.13
./configure
make all
make install-plugin
make install-daemon
make install-daemon-config
htpasswd -bc /usr/local/nagios/etc/htpasswd.users nagiosadmin
nagiosadmin101
echo "alias nagioscheck='/usr/local/nagios/bin/nagios -v
/usr/local/nagios/etc/nagios.cfg' " >> /root/.bashrc
source /root/.bashrc
chkconfig nagios on
chkconfig httpd on
service httpd start
service nagios start

#基本安装过程这里就不重复了,htpasswd -bc这行代码的做用是不须要人为干预的生成密码名为nagiosadmin101的angiosadmin用户,然后期因为常常要修改/usr/local/nagios/etc/nagios.cfg配置文件,因此须要检测其语法,因此将其长命令生成名为nagioscheck的别名命令。
mysql


Nagios客户端自动安装脚本,以下所示:ios

useradd nagios
cd /usr/local/src
wget http://nchc.dl.sourceforge.net/sourceforge/nagiosplug/nagios-plugins-1.4.13.tar.gz
wget http://prdownloads.sourceforge.net/sourceforge/nagios/nrpe-2.13.tar.gz
tar zxvf nagios-plugins-1.4.13.tar.gz
cd nagios-plugins-1.4.13
./configure
make
make install
chown nagios:nagios /usr/local/nagios
chown -R nagios:nagios /usr/local/nagios/libexec
cd ../
tar zxvf nrpe-2.13.tar.gz
cd nrpe-2.13
./configure
make all
make install-plugin
make install-daemon
make install-daemon-config
sed -i 's@allowed_hosts=127.0.0.1@allowed_hosts=114.112.11.11@'/usr/local/nagios/etc/nrpe.cfg
/usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d
echo "/usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d" >> /etc/rc.local

#allowed_hosts这行是将原先的127.0.0.1由如今的服务器地址114.112.11.11地址代替(已做无害处理),这行代码你们能够根据实际须要考虑是否增长,接下来的工做就是调试Nagios服务器端了,具体过程这里略过。
c++


事实上,在机器进IDC机房以前,像nagios和puppet客户端软件,应该在每台上线机器上部署安装好,机器上线前确定首先是集中在本身的局域网内Kickstart后而后初始化,这时网络稳定、调试也方便,因此用puppet自动化维化既方便又省力,这样省得机器上线之后又远程维护安装,即耗了人力成本,并且也增长了机器风险。另注:我看许多朋友都是自行编写SHELL脚本做为Nagios插件来做为对MySQL主从同步的补充功能,其实Nagios中有自带的check_mysql及check_mysql_health插件来实现,因为check_mysql在部署过程当中总是频繁报“段错误”,因此目前主要仍是用check_mysql_health,由于咱们不单单是监控从机上面的SQL和IO进程,更重要的是,咱们要监控从机的延迟时间。
web

相关文章
相关标签/搜索