zhendeaini123 发表于 2019-1-11 10:28:41

三种监控平台配置及其整合(cacti nagios ganglia)

  三种软件的官方文档地址:
  cacti:http://docs.cacti.net/manual:087:1_installation#installation
  nagios:http://www.nagios.org/documentation
  ganglia:http://ganglia.info/
  在监控平台领域,这三款监控软件各有所长各有所短,这篇文档先介绍三款软件的安装配置方法,然后再将三种软件整合起来,使得每款软件的优点得到利用。
  系统环境:rhel6 selinux and iptables disabled
  cacti:

  cacti软件通过net-snmp协议定时采集主机信息,并保存在mysql数据库中,当用户要查看的时候数据库中找到对应的rra文件,通过rrdtool软件进行绘图,然后将图形返回给用户。他的优势在于可以生成直观的报表。
  所以cacti运行的前提是安装了rrdtool,mysql,php以及一个网页发布程序,本文采用apache。
  首先安装需要的软件及依赖性:


[*]# yum install httpd mysql mysql-server mysql-devel php php-mysql php-snmp net-snmp net-snmp-utils net-snmp-libs net-snmp-devel libart_lgpl-devel libpng-devel freetype-devel cairo-devel pango-devel gcc make

  注意php-snmp包在Optional库里
  安装好以后启动mysql和apache


[*]# /etc/init.d/httpd start
[*]# /etc/init.d/mysqld start

  配置PHP:只需要修改/etc/php.ini文件,将时区设置为上海:
  date.timezone = Asia/shanghai
  配置snmp:
  cacti官方文档中snmp的配置过于繁琐,建议按照http://www.cyberciti.biz/nixcraft/linux/docs/uniqlinuxfeatures/mrtg/mrtg_config_step_3.php中的步骤进行配置。


[*]# vi /etc/snmp/snmpd.conf

  对配置中的一些语句进行替换


[*]#com2sec notConfigUserdefault       public
[*]com2sec local   localhost         public
[*]com2sec mynetwork 192.168.0.0/24      public
[*]
[*]#group   notConfigGroup v1         notConfigUser
[*]#group   notConfigGroup v2c         notConfigUser
[*]group MyRWGroup v1         local
[*]group MyRWGroup v2c      local
[*]group MyRWGroup usm      local
[*]group MyROGroup v1         mynetwork
[*]group MyROGroup v2c      mynetwork
[*]group MyROGroup usm      mynetwork
[*]
[*]
[*]#view    systemview    included   .1.3.6.1.2.1.1
[*]#view    systemview    included   .1.3.6.1.2.1.25.1.1
[*]view all    included.1
[*]
[*]#accessnotConfigGroup ""      any       noauth    exactsystemview none none
[*]access MyROGroup ""      any       noauth    exactall    none   none
[*]access MyRWGroup ""      any       noauth    exactall    all    none
[*]
[*]#syslocation Unknown (edit /etc/snmp/snmpd.conf)
[*]#syscontact Root(configure /etc/snmp/snmp.local.conf)
[*]syslocation Linux (RH3_UP2), Home Linux Router.
[*]syscontact yejk

启动snmpd




[*]# chkconfig snmpd on
[*]# service snmpd start

  安装rrdtool


[*]# yum installlibxml2-devel
[*]# tar zxf rrdtool-1.4.4.tar.gz
[*]# cd rrdtool-1.4.4
[*]# ./configure
[*]# make
[*]# make install
[*]# ln -s/opt/rrdtool-1.4.4/bin/rrdtool/usr/local/bin

  安装cacti:


[*]# tar zxf cacti-0.8.7h.tar.gz
[*]# mv cacti-0.8.7h /var/www/html/cacti
[*]# cd /var/www/html/cacti/
[*]# useradd cacti
[*]# chown -R cacti rra log
[*]# mysql cacti < cacti.sql

  在数据库中创建一个供cacti使用的用户,仅有对cacti库操作的权限:


[*]#mysql
[*]mysql> grant all on cacti.* to cacti@localhost identified by 'cacti';
[*]mysql> flush privileges;
[*]mysql> quit

  编辑cacti的配置文件,修改登录数据库的用户和密码


[*]# vim include/config.php
[*]$database_type = &quot;mysql&quot;;
[*]$database_default = &quot;cacti&quot;;
[*]$database_hostname = &quot;localhost&quot;;
[*]$database_username = &quot;cacti&quot;;
[*]$database_password = &quot;cacti&quot;;
[*]$database_port = &quot;3306&quot;;
[*]$database_ssl = false;
[*]$url_path = &quot;/cacti/&quot;;

  为cacti用户写一个crontab,使他没五分钟收集一次主机信息


[*]# su - cacti
[*]$ crontab -e
[*]*/5 * * * * cactiuser php /var/www/html/cacti/poller.php > /dev/null 2>&1

  安装cacti加速器:cacti-spine:


[*]# yum install automake libtool
[*]# tar zxf cacti-spine-0.8.7h.tar.gz
[*]# cd cacti-spine-0.8.7h
[*]# aclocal
[*]# libtoolize --force
[*]# autoheader
[*]# autoconf
[*]# automake
[*]# ./configure
[*]# make
[*]# make install
[*]# cd /usr/local/spine/etc/
[*]# mv spine.conf.dist spine.conf
[*]# vim spine.conf
[*]DB_Host         localhost
[*]DB_Database   cacti
[*]DB_User         cacti
[*]DB_Pass         cacti
[*]DB_Port         3306
[*]DB_PreG         0

  打开http://192.168.0.100/cacti
  在console-settings-paths-alternate poller path 写上 /usr/local/spine/bin/spine
  再将console-settings-poller-poller type改为spine
  注意如果文字是乱码的话需要安装中文支持
  安装cacti插件管理器:
  cacti可以通过安装插件大大丰富它的功能,插件安装叶非常简便,只要安装好插件管理器以后将要安装的插件文件夹放在/var/www/html/cacti/plugins中就可以在网页里进行安装。下面时安装插件管理器的方法:


[*]# tar zxf cacti-plugin-0.8.7h-PA-v3.0.tar.gz
[*]# cd cacti-plugin-arch/
[*]# mysql -ucacti -pcacti cacti < pa.sql
[*]# cp cacti-plugin-0.8.7h-PA-v3.0.diff /var/www/html/cacti/
[*]# cd /var/www/html/cacti/
[*]# patch -p1 -N < cacti-plugin-0.8.7h-PA-v3.0.diff

  打开http://192.168.0.100/cacti
  在console-utilities-user management-admin-realm permissions勾选plugin management
  安装三款插件:


[*]tar zxf settings-0.5.tar.gz -C /usr/local/apache/htdocs/cacti/plugins
[*]
[*]tar zxf monitor-0.8.2.tar.gz -C /usr/local/apache/htdocs/cacti/plugins
[*]
[*]tar zxf thold-0.4.2.tar.gz -C /usr/local/apache/htdocs/cacti/plugins

  打开http://192.168.0.100/cacti,进入插件管理器可直接进行安装,并可在settings中进行设置。
  一些cacti简单的介绍:
  Cacti 其实是一套 php 程序,一个 rrdtool 工具。它运用 snmpget 采集数据,使用 rrdtool 绘图。界面非常漂亮,它提供了强大的数据管理和用户管理功能,一张图是属于一个 host 的,每一个 host 又可以挂载到一个树状的结构上。用户的管理上,作为一个开源软件,它做到为指定一个用户能查看的“树”、host、甚至每一张图,还可以与 LDAP 结合进行用户的验证。 Cacti 还提供自己增加模板的功能,让你添加自己的 snmp_query和 script 。功能相当强大!
  cacti 是用 php 语言实现的一个软件,它的主要功能是用 snmp 服务获取数据, snmp 需要的变量数据是通过读取 mysql 数据库得到,然后用 rrdtool 储存和更新数据,当用户需要查看数据的时候用 rrdtool 生成图表呈现给用户。rrdtool 对数据的更新和存储就是对 rrd 文件的处理,rrd 文件是大小固定的档案文件,它能够存储的数据笔数在创建时就已经定义。1. Snmp 用来收集数据;2. Rrdtool 用来存储数据和生成图表;3. Mysql 用来配合 PHP 程序存储一些变量数据并对变量数据进行调用。



nagios:

cacti默认是以邮件发送警告信息的,虽然可以安装插件以实现其他方式进行告警,但不是他的强项,nagios有着强大的报警机制,下面是部署方法:




[*]# yum install httpd gcc make gd-devel perl-ExtUtils-Embed #安装编译所需要的软件包
[*]# useradd nagios #运行nagios服务的用户
[*]# usermod -G nagios apache #将apache用户加入到nagios组中,因为nagios程序通过apache发布与修改,而httpd程序的执行用户是apache,所以需要让apache有权限修改查看nagios文件
[*]# tar jxf nagios-cn-3.2.3.tar.bz2
[*]# cd nagios-cn-3.2.3
[*]# ./configure --enable-embedded-perl
[*]# make
[*]# make all
[*]# make install
[*]# make install-init
[*]# make install-commandmode
[*]# make install-config
[*]# make install-webconf

  安装nagios插件:


[*]# yum install mysql-devel openssl-devel -y #安装编译所需的安装包
[*]# tar zxf nagios-plugins-1.4.15.tar.gz
[*]# cd nagios-plugins-1.4.15
[*]# ./configure --with-nagios-user=nagios --with-nagios-group=nagios --enable-extra-opts --enable-libtap --enable-perl-modules
[*]# make
[*]# make install

  #nagios 配置


[*]# vi /usr/local/nagios/etc/nagios.cfg #nagios 配置
[*]cfg_file=/usr/local/nagios/etc/objects/hosts.cfg
[*]#新建 hosts.cfg 文件,存放主机与主机组定义
[*]cfg_file=/usr/local/nagios/etc/objects/services.cfg #新建 services.cfg 文件,存放服务与服务组定义
[*]#cfg_file=/usr/local/nagios/etc/objects/localhost.cfg#注释 localhost.cfg 文件

  注意,这里软件装好的时候默认时读取licalhost.cfg这个文件中的被监控的主机与服务的设置,我们把它注释掉,新加入两个文件,分别管理被监控的主机、主机组与被监控的服务与服务组
  编辑被监控主机与主机组的文件:


[*]# cd /usr/local/nagios/etc/objects
[*]# vim /usr/local/nagios/etc/objects/hosts.cfg
[*]
[*]define host{
[*]      use                     linux-server
[*]      host_name               监控主机
[*]      alias                   nagios 服务器
[*]      address               127.0.0.1
[*]      icon_image            web.gif
[*]      statusmap_image         web.gd2
[*]      2d_coords               100,300
[*]      3d_coords               100,300,100
[*]      }
[*]
[*]define hostgroup{               ;主机组不是必须的
[*]      hostgroup_namelinux-servers
[*]      alias         Linux Servers         
[*]      members         *   
[*]      }

  编辑被监控服务的时候因为内容很多,所以可以拷贝原来的localhost.cfg文件进行一些修改来使用:


[*]cp localhost.cfg services.cfg

  对services.cfg进行修改,在vi编辑器中的命令模式下用d1G去掉servicegroup以上的hosts部分,并用:%s/田朝阳家用机/监控主机/g命令将文件中用于被监控的主机全部改为刚刚在hosts文件中设置的主机,并在servicegroup部分做如下修改,其他不变:


[*]define servicegroup{
[*]      servicegroup_name 系统负荷检查
[*]      alias 负荷检查
[*]      members 监控主机,进程总数,监控主机,登录用户数,监控主机,根分区,监控主机,>交换空间利用率
[*]      }
[*]
[*]define servicegroup{
[*]      servicegroup_name 全部联通性检查
[*]      alias 联通性检查
[*]      members 监控主机,PING
[*]      }

  使用命令


[*]# htpasswd -c /usr/local/nagios/etc/htpasswd.users nagiosadmin

  修改nagios管理员的登录密码,注意必须是nagiosadmin,否则可以登录但是无法查看状态
  使用命令


[*]/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg

  校验配置文件语法的正确性,没有错误的话


[*]service nagios start
[*]service httpd start

  用nagios监控 mysql 主机
  在mysql服务器端创建一个监控检测账户,只给select权限,不需要密码:


[*]mysql> create database nagdb;
[*]mysql> grant select on nagdb.* to nagdb@'192.168.0.86' ;
[*]mysql> flush privileges;

  在 nagios 主机上检测是否可以连接 mysql 主机上的 mysql 服务


[*]/usr/local/nagios/libexec/check_mysql -H 192.168.0.36 -u nagdb -d nagdb
[*]Uptime: 286Threads: 1Questions: 16Slow queries: 0Opens: 15Flush tables: 1Open tables: 8Queries per second avg: 0.55




页: [1]
查看完整版本: 三种监控平台配置及其整合(cacti nagios ganglia)