设为首页 收藏本站
查看: 853|回复: 0

[经验分享] CentOS下搭建cacti监控

[复制链接]

尚未签到

发表于 2019-1-9 11:56:36 | 显示全部楼层 |阅读模式
  一、cacti 监控软件简介
1. cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用rrdtool生成图表呈现给用户。因此,snmprrdtoolcacti的关键。Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成。
2. Mysql配合PHP程序存储一些变量数据并对变量数据进行调用,如:主机名、主机ipsnmp团体名、端口号、模板信息等变量
3. snmp抓到数据不是存储在mysql中,而是存在rrdtool生成的rrd文件中(在cacti根目录的rra文件夹下)。rrdtool对数据的更新和存储就是对rrd文件的处理,rrd文件是大小固定的档案文件(RoundRobinArchive),它能够存储的数据笔数在创建时就已经定义。
  二、搭建cacti 监控环境
  1、搭建环境介绍:



  服务端
  CentOS
  *.*.*.*
  客户端
  任意网络设备
  192.168.1.110
  2、关闭iptables和SElinux
  [root@localhost configs]# iptables -F
[root@localhost configs]# setenforce 0

  3cacti 服务端操作:
  [root@localhost/]# yum install  epel-release   //安装epel扩展源,为下面安装cacti做准备
  [root@localhost/]# yum install -y  httpd php php-mysql mysql mysql-server mysql-devel php-gd  libjpeg libjpeg-devel libpng libpng-devel  //安装cacti相关的php、mysql软件
  [root@localhost/]# yum install -y cacti  net-snmp  net-snmp-utils  rrdtool  //安装cactinet-snmprrdtool
  
  这里cacti的安装可以用yum 直接安装,也可以自己通过wget 下载tar.gz相关安装包下载,唯一的区别是yum安装,在配置cacti.conf文件时,yum是自动生成的,只需要修改里面相应的参数,下面配置会有说明,这里简单的说下通过解压包安装时怎么来手动配置cacti.conf文件。
  首先先说明下,如果没有配置cacti.conf文件,我们在进入cacti的安装向导时会报错,URL不正确之类信息。
  所以这是必须配置的,网上的文章十有八九都是抄袭,没有这块的说明,有的也说的不详细,主要前期自己在这一块也是折腾了好久,so特此说明一下:
  下面说下如何配置手动配置cacti.conf文件
  进入到[root@localhost/]# cd /etc/httpd/conf.d/目录下
  手动重建cacti.conf文件
  [root@localhost/]# vi cacti.conf
  
  Alias /cacti/ "/usr/share/cacti/"
  
  Options Indexes MultiViews FollowSymLinks
  AllowOverride None
  Order allow,deny
  Allow from all
  
  然后保存退出
  这样配置以后就可以进入cacti安装向导了。

  

  启动服务:
  [root@localhost/]# /etc/init.d/mysqld start
  [root@localhost/]# /etc/init.d/httpd start
  [root@localhost/]# /etc/init.d/snmpd start
  
  更改httpd配置文件:
  [root@localhost/]# vi /etc/httpd/conf.d/cacti.conf  //将配置文件的"Deny from all" 改为  "Allow from all"
  [root@localhost/]# /etc/init.d/httpd restart
  
  导入数据创建cacti库:
  [root@localhost/]# mysql -uroot -e "create database cacti"
  [root@localhost/]# mysql -uroot -e "grant all on cacti.* to 'cacti'@'127.0.0.1' identified by 'cacti';"
  [root@localhost/]# mysql -uroot  cacti < /usr/share/doc/cacti-1.1.19/cacti.sql
  
  编辑cacti配置文件:
  [root@localhost/]# vi /usr/share/cacti/include/config.php
  $database_type =&quot;mysql&quot;; 数据库名称
  $database_default= &quot;cacti&quot;;数据库名称
  $database_hostname= &quot;127.0.0.1&quot;;主机名称
  $database_username= &quot;cacti&quot;;数据库用户名
  $database_password= &quot;cacti&quot;;数据库密码
  $database_port =&quot;3306&quot;;
  $database_ssl =false;
  *注意*:这块的信息必须和数据用户信息、密码对应,负责会报错:
  +---------------------------------------+
| query                                 |
+---------------------------------------+
| User: 'cacti'@'127.0.0.1';            |
| User: 'root'@'127.0.0.1';             |
| User: ''@'localhost';                 |
| User: 'cactiuser'@'localhost';        |
| User: 'root'@'localhost';             |
| User: ''@'localhost.localdomain';     |
| User: 'root'@'localhost.localdomain'; |
+---------------------------------------+
  
  $database_type =&quot;mysql&quot;; 数据库名称
  $database_default= &quot;cacti&quot;;数据库名称
  $database_hostname= &quot;127.0.0.1&quot;;主机名称
  $database_username= &quot;cacti&quot;;数据库用户名
  $database_password= &quot;cacti&quot;;数据库密码
  $database_port =&quot;3306&quot;;
  $database_ssl =false;
  
  存在用户名密码不匹配的,参照一下修改:
  查看MYSQL数据库中所有用户:
  mysql> SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;
+---------------------------------------+
| query                                 |
+---------------------------------------+
| User: 'cacti'@'127.0.0.1';            |
| User: 'root'@'127.0.0.1';             |
| User: ''@'localhost';                 |
| User: 'cactiuser'@'localhost';        |
| User: 'root'@'localhost';             |
| User: ''@'localhost.localdomain';     |
| User: 'root'@'localhost.localdomain'; |
+---------------------------------------+
  修改密码,刷新权限:
  mysql> grant all on cacti.* to 'cacti'@'127.0.0.1' identified by '321321';
Query OK, 0 rows affected (0.00 sec)
  mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)重启mysql httpd服务:
在安装cacti时,有一段报错
  1
  ERROR: Your Cacti database login account does not have access to the MySQL TimeZone database. Please provide the Cacti database account &quot;select&quot; access to the &quot;time_zone_name&quot; table in the &quot;mysql&quot; database, and populate MySQL's TimeZone information before proceeding.
解决办法:登录mysql,执行以下内容
  mysql> GRANT SELECT ON mysql.time_zone_name TO cacti@localhost IDENTIFIED BY 'cactiwhsir';
  mysql> flush privileges;
然后发现又报错
  ERROR: Your MySQL TimeZone database is not populated. Please populate this database before proceeding.
  解决办法:登录mysql,执行以下内容
  mysql_tzinfo_to_sql /usr/share/zoneinfo/Asia/Shanghai Shanghai | mysql -u root -p mysql

  
  调整httpd配置,将cacti源码目录作为网站根目录
  Vi/etc/httpd/conf/httpd.conf
  # documents. By default, all requests are taken from this directory, but
# symbolic links and aliases may be used to point to other locations.
#
DocumentRoot &quot;/usr/share/cacti/&quot;
  

  3web访问cacti并安装
  http://ip/cact
  



  

  上面三步按照系统默认步骤点击;

  第一次进入cacti输入管理密码时帐号和密码均为admin,输入后系统默认要求用户强制更改密码;
  

  4、执行poller.php, 生成图形,加入计划任务
  [root@localhost/]# /usr/bin/php /usr/share/cacti/poller.php
  OK u:0.01 s:0.02 r:0.67
  OK u:0.01 s:0.02 r:0.67
  OK u:0.01 s:0.02 r:0.71
  OK u:0.01 s:0.02 r:0.71
  OK u:0.01 s:0.02 r:0.78
  OK u:0.01 s:0.02 r:0.78
  OK u:0.01 s:0.02 r:0.84
  OK u:0.01 s:0.02 r:0.84
  OK u:0.01 s:0.02 r:1.00
  OK u:0.01 s:0.02 r:1.00
  06/17/2015 02:53:39 AM - SYSTEM STATS: Time:1.2623 Method:cmd.php Processes:1 Threads:N/A Hosts:2 HostsPerProcess:2 DataSources:5 RRDsProcessed:5
  [root@localhost/]# crontab -e //加入cron服务,让图片上的流量定时变动
  */5 * * * *  /usr/bin/php /usr/share/cacti/poller.php
  
  5、以下是在客户端:
  [root@hpf-linux mysql]# yum install -y net-snmp lm_sensors
  [root@hpf-linux/]# vi /etc/snmp/snmpd.conf //修改syslocation以及syscontact, 其中syslocation 可以写监控客户机的ipsyscontact写管理员邮箱
  syslocation 192.168.1.110
  syscontact Root aming@linux.com
  同时在配置文件内按以下修改,若不修改则会造成在添加网卡检测时会无法找到网卡选项;
  view   systemview    included   .1.3.6.1.2.1.1
  修改为:
  view   systemview    included   .1.3.6.1.2.1
  [root@hpf-linux/]# /etc/init.d/snmpd start
  正在启动 snmpd                                           [确定]
  
  6、浏览器下配置cacti 检测
  进入浏览器登录cacti管理后台,点console , 再点New Graphs在右上角点”Create New Host“

  Description  写监控客户机的名字或自定义
  Hostname   写被监控客户机ip
  Host Template ucd/net  SNMP Host
  SNMP Version Version 2
  点右下角的create  


  出现snmp的介绍信息后,点右上角的”CreateGraphs for this Host“;


  在下面框中选择要监控的硬件信息或者网卡,比如选择eth0,eth1, 在最右侧小方块里打对勾,然后点右下角的create;


  Graph Types: 再选择 Graph Template Based,在下面的框中,选择你要监控的项目,比如Unix- Load Average,在右侧小方块中打对勾,然后点右下角的createhttp://s4.运维网.com/wyfs02/M01/85/73/wKioL1ej6xvjSpzmAANZjyCnIck420.png-wh_500x0-wm_3-wmp_4-s_2434418081.png
   点左侧的Graph Trees ,选中”DefaultTree“,点右上角的Add;
  

  Tree Item Type 选择 ”Host“,Host 选择我们刚刚增加的那个机器ip,点右下角的create;
  点左上角的Graphs按钮 ,在左侧可以看到,Defaut Tree下面已经增加了我们刚刚添加的主机,图形一开始不会那么快出来,要等一小会才可以。
  

  ********************************************************************************************************
  不出图,主机状态为unkonwn,snmp等其他信息都正常
  可能是时间问题引起的,这时候可以看看cacti的日志,注意看开始时间和结束时间(这是由于系统每过10分钟会和时间服务器同步一次时间)。

  这样会导致数据库记录poller的执行时间出问题
  这时候查看下poller的始终时间,始终时间一定要正确这样会导致poller进程停止工作,直到系统时间超过了start_time,poller进程才回开始工作,图像才能出来!这里要特别说明下:不能简单地修改数据库poller_time表里的时间,因为数据库里面还有好多表也记录了采集各种数据的时间。

  所以解决办法有两个:
1 等系统时间超过start_time(过了下午12点10),一切恢复正常(如果你有耐心http://www.cnyunwei.com/static/image/smiley/default/lol.gif )。
2 如果现在系统的时间不正确先把系统时间修改正确,然后删除/usr/share/cacti/rra下面的所有文件,最后强制执行poller程序重新生成/usr/share/cacti/rra下面的所有文件。操作过程如下:
  [root@zz cacti]# rm -rf /usr/share/cacti/rra/*
  [root@zz cacti]# /usr/bin/php /usr/share/cacti/poller.php --force
OK u:0.00 s:0.00 r:0.05
OK u:0.00 s:0.00 r:0.05
OK u:0.00 s:0.00 r:0.07
OK u:0.00 s:0.00 r:0.07
OK u:0.00 s:0.00 r:0.11
OK u:0.00 s:0.00 r:0.11
OK u:0.00 s:0.00 r:0.17
OK u:0.00 s:0.00 r:0.17
OK u:0.00 s:0.00 r:0.27
OK u:0.00 s:0.00 r:0.27
OK u:0.00 s:0.00 r:0.29
OK u:0.00 s:0.00 r:0.29
OK u:0.00 s:0.00 r:0.30
OK u:0.00 s:0.00 r:0.30
OK u:0.00 s:0.01 r:0.31
OK u:0.00 s:0.01 r:0.32
OK u:0.00 s:0.01 r:0.34
OK u:0.00 s:0.01 r:0.34
10/28/2016 11:58:02 AM - SYSTEM STATS: Time:0.4926 Method:cmd.php Processes:1 Threads:N/A Hosts:4 HostsPerProcess:4 DataSources:13 RRDsProcessed:9
10/28/2016 11:58:02 AM - WEATHERMAP: Poller[0] Weathermap 0.97a starting - Normal logging mode. Turn on DEBUG in Cacti for more information

10/28/2016 11:58:02 AM - WEATHERMAP: Poller[0] STATS: Weathermap 0.97a run complete - Fri, 28 Oct 16 11:58:02 +0800: 0 maps were run in 0 seconds with 0 warnings.
  注意一定要先删除usr/share/cacti/rra/下的所有文件在执行
  /usr/bin/php /usr/share/cacti/poller.php --force,不然有些rra会报时间错误!
等一会久违的图像就出来啦...




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-661202-1-1.html 上篇帖子: cacti不出图基于时区的原因 下篇帖子: CentOS6.5下Cacti安装过程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表