监控cacti/nagios/zabbix

郗唯
2023-12-01

常用的监控软件有:cacti、nagios、zabbix等

cacti 重图形,有数据历史,需用到数据库支持,支持web配置,默认不支持告警,可以加插件;
nagios重状态和结果,没有数据历史,不成图像,不支持web配置,可以自己开发脚本定制个性化监控,支持多种插件;
zabbix有数据历史,可成图像,支持web配置,可以自动发现;
关于cacti 大家可以参考6期同学的笔记,有图很直观 (http://mylinuxlife.blog.51cto.com/4706737/1661680

第一部分:cacti安装配置
1. 首先要安装epel扩展源
yum install epel-release

  1. (lamp)然后分别安装httpd、php、mysql
    yum install -y httpd php php-mysql mysql mysql-server mysql-devel php-gd libjpeg libjpeg-devel libpng libpng-devel

  2. 安装cacti net-snmp rrdtool
    yum install -y cacti net-snmp net-snmp-utils rrdtool

  3. 启动服务:
    /etc/init.d/mysqld start
    /etc/init.d/httpd start
    /etc/init.d/snmpd start

  4. 编辑httpd配置文件
    vim /etc/httpd/conf.d/cacti.conf
    把”Deny from all” 改为 “Allow from all”
    /etc/init.d/httpd restart

  5. 导入数据创建cacti库
    mysql -uroot -e “create database cacti”

创建cacti用户
mysql -uroot -e “grant all on cacti.* to ‘cacti’@’127.0.0.1’ identified by ‘cacti’;”

导入sql文件
mysql -uroot cacti < /usr/share/doc/cacti-0.8.8b/cacti.sql

  1. 编辑cacti配置文件
    vim /usr/share/cacti/include/config.php 更改如下:
    databasetype=mysql; database_default = “cacti”;
    databasehostname=127.0.0.1; database_username = “cacti”;
    databasepassword=cacti; database_port = “3306”;
    $database_ssl = false;

  2. web访问cacti并安装
    http://ip/cacti/
    点两下“next” 和一次”Finish“ 即可
    输入admin admin 登录,重新设置新的密码

  3. 执行poller.php, 生成图形, 加入计划任务
    /usr/bin/php /usr/share/cacti/poller.php添加cron任务
    cront -e 增加:
    /5 * * * /usr/bin/php /usr/share/cacti/poller.php

以下10-12步骤在客户端机器上操作
10. 安装snmp
yum install -y net-snmp

  1. 修改snmpd.conf
    修改syslocation以及syscontact, 其中syslocation 可以写本机ip,syscontact写管理员邮箱

syslocation 11.20
syscontact Root 1212@1212.com

  1. 启动snmp
    service snmpd start

  2. 登录cacti管理后台,点console , 再点Device, 在右上角点”Add“
    Description 写本机ip或你自定义一个名字
    Hostname 写本机ip
    Host Template 选ucd/net SNMP Host
    SNMP Version 选Version 2
    点右下角的create
    点右上角的”Create Graphs for this Host“
    Graph Types: 选择SNMP - Interface Statistics
    在下面框中选择要监控的网卡,比如我选择eth0, 在最右侧小方块里打对勾,然后点右下角的create(如果在这一步找不到网卡,可以根据这个帖子修改配置文件http://www.apelearn.com/bbs/thread-8089-1-1.html
    Graph Types: 再选择 Graph Template Based
    在下面的框中,选择你要监控的项目,比如ucd/net - Load Average
    在右侧小方块中打对勾,然后点右下角的create

  3. 点左侧的Graph Trees
    选中”Default Tree“
    点右上角的Add
    Tree Item Type 选择 ”Host“
    Host 选择我们刚刚增加的那个机器ip
    点右下角的create

  4. 点左上角的Graphs
    在左侧可以看到
    Defaut Tree下面已经增加了我们刚刚添加的主机,图形一开始不会那么快出来,要等一小会才可以。

参考文章 http://www.it165.net/admin/html/201310/1956.html http://www.aminglinux.com/bbs/se … submit=yes&kw=cacti

第二部分:nagios安装配置:
Nagios官网 http://www.nagios.org

  1. Nagios安装 - 服务端(192.168.0.11)
    Centos6默认的yum源里没有nagios相关的rpm包,但是我们可以安装一个epel的扩展源:
    yum install -y epel-release

然后安装nagios相关的包
yum install -y httpd nagios nagios-plugins nagios-plugins-all nrpe nagios-plugins-nrpe
设置登录nagios后台的用户和密码:htpasswd -c /etc/nagios/passwd nagiosadmin
vim /etc/nagios/nagios.cfg
nagios -v /etc/nagios/nagios.cfg 检测配置文件
启动服务:service httpd start; service nagios start
浏览器访问: http://ip/nagios

  1. Nagios安装 - 客户端(192.168.0.12)
    在客户端机器上
    yum install -y epel-release
    yum install -y nagios-plugins nagios-plugins-all nrpe nagios-plugins-nrpe
    vim /etc/nagios/nrpe.cfg 找到“allowed_hosts=127.0.0.1” 改为 “allowed_hosts=127.0.0.1,192.168.0.11” 后面的ip为服务端ip; 找到” dont_blame_nrpe=0” 改为 “dont_blame_nrpe=1”
    启动客户端 /etc/init.d/nrpe start

  2. 监控中心(192.168.0.11)添加被监控主机(192.168.0.12)
    cd /etc/nagios/conf.d/
    vim 192.168.0.12.cfg //加入:
    define host{
    use linux-server
    host_name 192.168.0.12
    alias 0.12
    address 192.168.0.12
    }

define service{
use generic-service
host_name 192.168.0.12
service_description check_ping
check_command check_ping!100.0,20%!200.0,50%
max_check_attempts 5
normal_check_interval 1
}

define service{
use generic-service
host_name 192.168.0.12
service_description check_ssh
check_command check_ssh
max_check_attempts 5 ;当nagios检测到问题时,一共尝试检测5次都有问题才会告警,如果该数值为1,那么检测到问题立即告警
normal_check_interval 1 ;重新检测的时间间隔,单位是分钟,默认是3分钟
notification_interval 60 ;在服务出现异常后,故障一直没有解决,nagios再次对使用者发出通知的时间。单位是分钟。如果你认为,所有的事件只需要一次通知就够了,可以把这里的选项设为0。
}

define service{
use generic-service
host_name 192.168.0.12
service_description check_http
check_command check_http
max_check_attempts 5
normal_check_interval 1
}

以上服务不依赖于客户端nrpe服务,我们可以想象,我们在自己电脑上可以使用ping或者telnet探测远程任何一台机器是否存活、是否开启某个端口或服务。 而当我们想要检测客户端上的某个具体服务的情况时,就需要借助于nrpe了,比如想知道客户端机器的负责或磁盘使用情况。

  1. 继续添加服务
    服务端vim /etc/nagios/objects/commands.cfg
    增加:define command{
    command_name check_nrpe
    command_line USER1 /check_nrpe -H HOSTADDRESS -c ARG1
    }
    继续编辑 vim /etc/nagios/conf.d/192.168.0.12.cfg
    增加如下内容:define service{
    use generic-service
    host_name 192.168.0.12
    service_description check_load
    check_command check_nrpe!check_load
    max_check_attempts 5
    normal_check_interval 1
    }

define service{
use generic-service
host_name 192.168.0.12
service_description check_disk_hda1
check_command check_nrpe!check_hda1
max_check_attempts 5
normal_check_interval 1
}

define service{
use generic-service
host_name 192.168.0.12
service_description check_disk_hda2
check_command check_nrpe!check_hda2
max_check_attempts 5
normal_check_interval 1
}

说明: check_nrpe!check_load :这里的check_nrpe就是在commands.cfg刚刚定义的,check_load是远程主机上的一个检测脚本
在远程主机上vim /etc/nagios/nrpe.cfg 搜索check_load,这行就是在服务端上要执行的脚本了,我们可以手动执行这个脚本
把check_hda1更改一下:/dev/hda1 改为 /dev/sda1
再加一行command[check_hda2]=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /dev/sda2
客户端上重启一下nrpe服务: service nrpe restart
服务端也重启一下nagios服务: service nagios restart

  1. 配置告警
    vim /etc/nagios/objects/contacts.cfg //增加:define contact{
    contact_name 123
    use generic-contact
    alias aming
    email lishiming2009@139.com
    }

define contact{
contact_name 456
use generic-contact
alias aaa
email aminglinux@139.com
}

define contactgroup{
contactgroup_name common
alias common
members 123,456
}

然后在要需要告警的服务里面加上contactgroup

define service{
use generic-service
host_name 192.168.0.12
service_description check_load
check_command check_nrpe!check_load
max_check_attempts 5
normal_check_interval 1
contact_groups common
notifications_enabled 1 ;是否开启提醒功能。1为开启,0为禁用。一般,这个选项会在主配置文件(nagios.cfg)中定义,效果相同。
notification_period 24x7 ;发送提醒的时间段。非常重要的主机(服务)我定义为7×24,一般的主机(服务)就定义为上班时间。如果不在定义的时间段内,无论什么问题发生,都不会发送提醒。
notification_options:w,u,c,r ;这个是service的状态。w为waning, u为unknown, c为critical, r为recover(恢复了),类似的还有一个 host对应的状态:d,u,r d = 状态为DOWN, u = 状态为UNREACHABLE , r = 状态恢复为OK,需要加入到host的定义配置里。
}

参考:
调用短信接口 http://www.aminglinux.com/bbs/thread-7380-1-1.html
整合微信 http://www.aminglinux.com/bbs/thread-7917-1-1.html

  1. 配置图形显示 pnp4nagios (请自行演示,课上不演示)
    (1)安装
    yum install pnp4nagios rrdtool

(2)配置主配置文件
vim /etc/nagios/nagios.cfg //修改如下配置

process_performance_data=1    
host_perfdata_command=process-host-perfdata
service_perfdata_command=process-service-perfdata 
enable_environment_macros=1     
复制代码

(3)修改commands.cfg
vim /etc/nagios/objects/commands.cfg //注释掉原有对process-host-perfdata和process-service-perfdata,重新定义

define command {  
       command_name    process-service-perfdata  
       command_line    /usr/bin/perl /usr/libexec/pnp4nagios/process_perfdata.pl  
}  

define command {  
       command_name    process-host-perfdata  
       command_line    /usr/bin/perl /usr/libexec/pnp4nagios/process_perfdata.pl -d HOSTPERFDATA  
}  
复制代码

(4)修改配置文件templates.cfg
vim /etc/nagios/objects/templates.cfg define host {
name hosts-pnp
register 0
action_url /pnp4nagios/index.php/graph?host= HOSTNAME &srv=HOST
process_perf_data 1
}
define service {
name srv-pnp
register 0
action_url /pnp4nagios/index.php/graph?host= HOSTNAME &srv= SERVICEDESC
process_perf_data 1
}

(5)修改host和service配置
vim /etc/nagios/conf.d/192.168.0.12.cfg
把 “define host{
use linux-server”
改为:
define host{
use linux-server,hosts-pnp

修改对应的service,比如

define service{
use generic-service
host_name 192.168.0.12
service_description check_disk_hda1
check_command check_nrpe!check_hda1
max_check_attempts 5
normal_check_interval 1
}
改为:
define service{
use generic-service,srv-pnp
host_name 192.168.0.12
service_description check_disk_hda1
check_command check_nrpe!check_hda1
max_check_attempts 5
normal_check_interval 1
}

(6) 重启和启动各个服务:
service nagios restart
service httpd restart
service npcd start

(7) 访问测试
两种访问方法:
ip/nagios/
ip/pnp4nagios/

第三部分: zabbix安装配置
1 安装zabbix
yum install -y epel-release
安装rpm包的lamp环境 yum install -y httpd mysql mysql-libs php php-mysql mysql-server php-bcmath php-gd php-mbstring
安装zabbix服务端:yum install zabbix20 zabbix20-agent zabbix20-server zabbix20-server-mysql zabbix20-web zabbix20-web-mysql net-snmp-devel
/etc/init.d/zabbix-server start; /etc/init.d/zabbix-agent start
/etc/init.d/httpd start;
修改一下mysql配置文件
vim /etc/my.cnf //修改或增加如下内容
[mysql]
default-character-set = utf8

[mysqld]
character_set_server = utf8

启动mysql服务
/etc/init.d/mysqld start

建库,导入数据
mysql -uroot -p -e “create database zabbix”
mysql -uroot -p –default-character-set=utf8 zabbix < /usr/share/zabbix-mysql/schema.sql
mysql -uroot -p –default-character-set=utf8 zabbix < /usr/share/zabbix-mysql/images.sql
mysql -uroot -p –default-character-set=utf8 zabbix < /usr/share/zabbix-mysql/data.sql

2.网页安装zabbix
浏览器访问 http://ip/zabbix, 默认会有“It is not safe to rely on the system‘s timezone settings ”这样的警告信息,需要vim /etc/php.ini 设置 date.timezone=“Asia/Shanghai”点next
解决相关的报错信息,点retry (vim /etc/php.ini)
输入mysql相关信息, 首先要测试一下,如果不通过,则需要调试,测试通过后,点next
Name 写127.0.0.1,(可以自定义)点next,再点next,最后点finish
默认管理员账号为 admin:zabbix
这时会遇到“zabbix server is not running”这样的错误,需要编辑一下 /etc/zabbix/zabbix_server.conf ,配置DBUser, DBPassword

  1. 接入要监控的主机
    在客户端上yum install zabbix20-agent
    vim /etc/zabbix_agentd.conf //更改Server=服务端ip; ServerActive=0.0.0.0:10050; Hostname=aming(自定义,但要唯一)
    启动客户端 /etc/init.d/zabbix-agent start
    服务端上命令行测试:zabbix_get -s 客户端ip -p10050 -k “system.hostname”
    在web界面下,点”configuration” –> “host” –> 右上角点”Create Host” 其中host name, visible name自定义,可以选择groups,这里默认即可,ip address 写入客户端ip
    配置监控项目模板:点“templates”, 点add, 在弹出的小窗口中选择Template OS Linux, 然后点select, 最后点save

4.自定义templates
Zabbix自带了很多模板,模板中有很多监控项目,比如CPU、网卡、内存、进程等等。使用系统自带模板有点太多了,所以我们可以自定义模板。点configuration 选择 templates,点右上角的create template
Template name和Visible name 自定义,Groups 选择templates, 点save
然后我们去挑选一些项目拷贝到该模板下:比如我们找到Template OS Linux 点一下items,选择我们想要的项目,然后在下面选择copy selected to … 然后点go
Group 选择templates, 找到刚才我们自定义的templates,点copy
点configuration 选择 templates可以看到新建的templates中已经有刚刚我们copy的items了
我们可以使用和上面相同的方法自定义拷贝Triggers(触发器 ),它用来设置告警的阀值,当然我们也可以自定义编辑它
监控客户端网卡流量 http://www.apelearn.com/bbs/thread-8091-1-1.html

  1. 配置发邮件
    yum install -y sendmail ;
    mkdir -p /home/zabbix/bin
    vim /home/zabbix/bin/baojing.sh //内容:

! /bin/bash

echo “ 3"|/bin/mails" 2” $1
chmod +x /home/zabbix/bin/baojing.sh

在zabbix_server.conf配置文件中,有参数AlertScriptsPath和ExternalScripts
AlertScriptsPath=/home/zabbix/bin/ —用户自定义的media types脚本
ExternalScripts=/home/zabbix/bin/ —用户自定义的检查的脚本(item)
这样才能找到你的脚本,因为你在frontend中只是输入脚本的名称,没有路径。

创建mediea types: “Administration” –>”Media types”,点击右上角“Create Media Type”其中Description填”baojing” 或其它自定义名称,Type选择”Script”,Script填”baojing.sh”然后点”Save”.
创建user: “Adimistration” –> “Users”在右上角,选择”Users”,点击”Create User”, alias: test1,自定义name和lastname password:123456;group 选择guest,回到上面点一下media,type 选择baojing,send to 写要发送邮件的邮箱,点add, 最后点save
创建action: “configuration” –> actions,右上角“Create Actions”, Name自定义,我这里写”baojing”,其他默认,然后点右侧的“Operations”下的“New”按钮,“Operation Type”选择“Send message”,“Send Message to”选择一个或多个要发送消息的用户组,Send to Users选择我们之前新增的test1, “Send only to”选择baojing , 点一下add
最后点save

zabbix历史记录乱码问题 http://caisangzi.blog.51cto.com/6387416/1313630
zabbix图形中乱码问题 http://www.apelearn.com/bbs/thread-8090-1-1.html
zabbix参考文章
http://www.iyunv.com/thread-22959-1-1.html
http://waringid.blog.51cto.com/65148/955939/
http://www.linuxidc.com/Linux/2014-11/109909.htm

自定义脚本: http://www.linuxidc.com/Linux/2013-11/92476.htm

原文:http://www.apelearn.com/bbs/forum.php?mod=viewthread&tid=8087&highlight=nagios

 类似资料: