cwx 发表于 2019-1-9 10:46:51

监控cacti/nagios/zabbix

  常用的监控软件有:cacti、nagios、zabbix等
  cacti 重图形,有数据历史,需用到数据库支持,支持web配置,默认不支持告警,可以加插件;
  nagios重状态和结果,没有数据历史,不成图像,不支持web配置,可以自己开发脚本定制个性化监控,支持多种插件;
  zabbix有数据历史,可成图像,支持web配置,可以自动发现;
  关于cacti 大家可以参考6期同学的笔记,有图很直观 (http://mylinuxlife.blog.运维网.com/4706737/1661680)
  第一部分:cacti安装配置
  1. 首先要安装epel扩展源
  yum installepel-release
  2. (lamp)然后分别安装httpd、php、mysql
  yum install -yhttpd php php-mysql mysql mysql-server mysql-devel php-gdlibjpeg libjpeg-devel libpng libpng-devel
  3. 安装cactinet-snmprrdtool
  yum install -y cactinet-snmpnet-snmp-utilsrrdtool
  4. 启动服务:
  /etc/init.d/mysqld start
  /etc/init.d/httpdstart
  /etc/init.d/snmpd start
  5. 编辑httpd配置文件
  vim /etc/httpd/conf.d/cacti.conf
  把"Deny from all" 改为"Allow from all"
  /etc/init.d/httpdrestart
  6.导入数据创建cacti库
  mysql -uroot-e "create database cacti"
  创建cacti用户

  mysql -uroot -e "grant all on cacti.* to 'cacti'@'127.0.0.1'>  导入sql文件
  mysql -uroot cacti < /usr/share/doc/cacti-0.8.8b/cacti.sql
  7.编辑cacti配置文件
  vim /usr/share/cacti/include/config.php更改如下:
  $database_type = "mysql";
  $database_default = "cacti";
  $database_name = "cacti";
  $database_hostname = "127.0.0.1";
  $database_username = "cacti";
  $database_password = "cacti";
  $database_port = "3306";
  $database_ssl = false;
  8. web访问cacti并安装
  http://ip/cacti/
  点两下“next” 和一次”Finish“ 即可
  输入admin   admin 登录,重新设置新的密码
  9. 执行poller.php, 生成图形, 加入计划任务
  /usr/bin/php /usr/share/cacti/poller.php添加cron任务
  crontab -e增加:
  */5 * * * */usr/bin/php /usr/share/cacti/poller.php
  以下10-12步骤在客户端机器上操作
  10. 安装snmp
  yum install -y net-snmp
  11. 修改snmpd.conf
  修改syslocation以及syscontact, 其中syslocation 可以写本机ip,syscontact写管理员邮箱
  syslocation 11.20
  syscontact Root 1212@1212.com
  12. 启动snmp
  servicesnmpdstart
  13.登录cacti管理后台,点console , 再点Device, 在右上角点”Add“
  Description写本机ip或你自定义一个名字
  Hostname写本机ip
  Host Template选ucd/netSNMP 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
  14. 点左侧的Graph Trees
  选中”Default Tree“
  点右上角的Add
  Tree Item Type 选择 ”Host“
  Host 选择我们刚刚增加的那个机器ip
  点右下角的create
  15. 点左上角的Graphs
  在左侧可以看到
  Defaut Tree下面已经增加了我们刚刚添加的主机,图形一开始不会那么快出来,要等一小会才可以。
  参考文章 http://www.it165.net/admin/html/201310/1956.html
  第二部分: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
  2. 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
  3. 监控中心(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了,比如想知道客户端机器的负责或磁盘使用情况。
  4.继续添加服务
  服务端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=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /dev/sda2
  客户端上重启一下nrpe服务: service nrpe restart
  服务端也重启一下nagios服务: service nagios restart
  5.   配置告警
  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_enabled1    ;是否开启提醒功能。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
  6.   配置图形显示 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 -yhttpd mysql mysql-libs php php-mysql mysql-server php-bcmath php-gd php-mbstring
  安装zabbix服务端:yum installzabbix20 zabbix20-agent zabbix20-serverzabbix20-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    //修改或增加如下内容
  
  default-character-set = utf8
  
  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=utf8zabbix < /usr/share/zabbix-mysql/data.sql
  2.网页安装zabbix

  浏览器访问 http://ip/zabbix, 默认会有“It is not safe to>  解决相关的报错信息,点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
  3. 接入要监控的主机
  在客户端上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
  5. 配置发邮件
  yum install -y sendmail ;
  mkdir -p /home/zabbix/bin
  vim /home/zabbix/bin/baojing.sh //内容:
  #! /bin/bash
  echo "$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历史记录乱码问题   http://caisangzi.blog.运维网.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.运维网.com/65148/955939/
  http://www.linuxidc.com/Linux/2014-11/109909.htm
  6期胡湘林同学的分享   http://xianglinhu.blog.运维网.com/5787032/d-6
  自定义脚本:   http://www.linuxidc.com/Linux/2013-11/92476.htm

页: [1]
查看完整版本: 监控cacti/nagios/zabbix