您的位置:首页 > 移动开发 > IOS开发

监控cacti/nagios/zabbix

2015-08-24 14:21 686 查看
常用的监控软件有:cacti、nagios、zabbix等

cacti 重图形,有数据历史,需用到数据库支持,支持web配置,默认不支持告警,可以加插件;

nagios重状态和结果,没有数据历史,不成图像,不支持web配置,可以自己开发脚本定制个性化监控,支持多种插件;

zabbix有数据历史,可成图像,支持web配置,可以自动发现;

关于cacti 大家可以参考6期同学的笔记,有图很直观 (/article/4396836.html

第一部分:cacti安装配置

1. 首先要安装epel扩展源

yum install epel-release

(lamp)然后分别安装httpd、php、mysql

yum install -y httpd php php-mysql mysql mysql-server mysql-devel php-gd libjpeg libjpeg-devel libpng libpng-devel

安装cacti net-snmp rrdtool

yum install -y cacti net-snmp net-snmp-utils rrdtool

启动服务:

/etc/init.d/mysqld start

/etc/init.d/httpd start

/etc/init.d/snmpd start

编辑httpd配置文件

vim /etc/httpd/conf.d/cacti.conf

把”Deny from all” 改为 “Allow from all”

/etc/init.d/httpd restart

导入数据创建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

编辑cacti配置文件

vim /usr/share/cacti/include/config.php 更改如下:

databasetype=“mysql”;database_type = “mysql”;
database_default = “cacti”;

databasehostname=“127.0.0.1”;database_hostname = “127.0.0.1”;
database_username = “cacti”;

databasepassword=“cacti”;database_password = “cacti”;
database_port = “3306”;

$database_ssl = false;

web访问cacti并安装

http://ip/cacti/

点两下“next” 和一次”Finish“ 即可

输入admin admin 登录,重新设置新的密码

执行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

修改snmpd.conf

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

syslocation 11.20

syscontact Root 1212@1212.com

启动snmp

service snmpd start

登录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

点左侧的Graph Trees

选中”Default Tree“

点右上角的Add

Tree Item Type 选择 ”Host“

Host 选择我们刚刚增加的那个机器ip

点右下角的create

点左上角的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

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

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

监控中心(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了,比如想知道客户端机器的负责或磁盘使用情况。

继续添加服务

服务端vim /etc/nagios/objects/commands.cfg

增加:define command{

command_name check_nrpe

command_line USER1USER1/check_nrpe -H HOSTADDRESSHOSTADDRESS -c ARG1ARG1

}

继续编辑 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

配置告警

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

配置图形显示 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=HOSTNAMEHOSTNAME&srv=HOST

process_perf_data 1

}

define service {

name srv-pnp

register 0

action_url /pnp4nagios/index.php/graph?host=HOSTNAMEHOSTNAME&srv=SERVICEDESCSERVICEDESC

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

接入要监控的主机

在客户端上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

配置发邮件

yum install -y sendmail ;

mkdir -p /home/zabbix/bin

vim /home/zabbix/bin/baojing.sh //内容:

! /bin/bash

echo “3"|/bin/mail−s"3" |/bin/mail -s "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历史记录乱码问题 /article/4576876.html

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: