我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CentOS下搭建cacti监控

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CentOS下搭建cacti监控


一、cacti 监控软件简介

1. cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用rrdtool生成图表呈现给用户。因此,snmp和rrdtool是cacti的关键。Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成。

2. Mysql配合PHP程序存储一些变量数据并对变量数据进行调用,如:主机名、主机ip、snmp团体名、端口号、模板信息等变量

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

3、cacti 服务端操作:

[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  //安装cacti、net-snmp、rrdtool

 

这里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/"


<Directory "/usr/share/cacti">

    Options Indexes MultiViews FollowSymLinks

    AllowOverride None

    Order allow,deny

    Allow from all

</Directory>

然后保存退出

这样配置以后就可以进入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 ="mysql"; 数据库名称

$database_default= "cacti";数据库名称

$database_hostname= "127.0.0.1";主机名称

$database_username= "cacti";数据库用户名

$database_password= "cacti";数据库密码

$database_port ="3306";

$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 ="mysql"; 数据库名称

$database_default= "cacti";数据库名称

$database_hostname= "127.0.0.1";主机名称

$database_username= "cacti";数据库用户名

$database_password= "cacti";数据库密码

$database_port ="3306";

$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 "select" access to the "time_zone_name" table in the "mysql" 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 "/usr/share/cacti/"

 

CentOS下搭建cacti监控

3、web访问cacti并安装

http://ip/cact

 

CentOS下搭建cacti监控

CentOS下搭建cacti监控

CentOS下搭建cacti监控


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

CentOS下搭建cacti监控

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

 

CentOS下搭建cacti监控

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 可以写监控客户机的ip,syscontact写管理员邮箱

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“;

CentOS下搭建cacti监控

Description  写监控客户机的名字或自定义

Hostname   写被监控客户机ip

Host Template 选ucd/net  SNMP Host

SNMP Version 选Version 2

点右下角的create 

CentOS下搭建cacti监控

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

CentOS下搭建cacti监控

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

CentOS下搭建cacti监控

Graph Types: 再选择 Graph Template Based,在下面的框中,选择你要监控的项目,比如Unix- Load Average,在右侧小方块中打对勾,然后点右下角的create; CentOS下搭建cacti监控

 点左侧的Graph Trees ,选中”DefaultTree“,点右上角的Add;

 

CentOS下搭建cacti监控

Tree Item Type 选择 ”Host“,Host 选择我们刚刚增加的那个机器ip,点右下角的create;

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

 

CentOS下搭建cacti监控

********************************************************************************************************

不出图,主机状态为unkonwn,snmp等其他信息都正常

可能是时间问题引起的,这时候可以看看cacti的日志,注意看开始时间和结束时间(这是由于系统每过10分钟会和时间服务器同步一次时间)。

这样会导致数据库记录poller的执行时间出问题

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

CentOS下搭建cacti监控

所以解决办法有两个:
1 等系统时间超过start_time(过了下午12点10),一切恢复正常(如果你有耐心CentOS下搭建cacti监控 )。
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会报时间错误!
等一会久违的图像就出来啦...


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CentOS下搭建cacti监控

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

CentOS搭建web服务器的日志管理与监控技巧

在CentOS上搭建web服务器时,日志管理和监控是非常重要的任务。以下是一些技巧,可用于有效地管理和监控日志:1. 使用日志轮转:默认情况下,CentOS会使用logrotate工具来轮转日志文件。您可以配置logrotate来定期压缩和
2023-10-09

Centos下怎么搭建Apache环境

今天小编给大家分享一下Centos下怎么搭建Apache环境的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Apache是世界
2023-06-28

centos下怎么搭建sockets5代理

在CentOS上搭建Socks5代理,可以使用Shadowsocks或者Dante来实现。下面是使用Shadowsocks搭建的步骤:1. 首先,确保CentOS已经安装了Python和pip。如果没有安装,可以运行以下命令进行安装:sud
2023-10-24

CentOS下如何搭建Windows虚拟机

在CentOS系统上搭建Windows虚拟机需要使用虚拟化技术,比如VirtualBox或者KVM。以下是使用VirtualBox搭建Windows虚拟机的步骤:安装VirtualBox在CentOS系统上安装VirtualBox可以使用以
CentOS下如何搭建Windows虚拟机
2024-05-06

CentOS7如何搭建Prometheus监控Linux主机

这期内容当中小编将会给大家带来有关CentOS7如何搭建Prometheus监控Linux主机,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 简介prometheus可以拆分成多个节点进行指标收集。安装环
2023-06-15

Centos下如何利用Nload监控网卡流量

这篇文章主要讲解了“Centos下如何利用Nload监控网卡流量”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Centos下如何利用Nload监控网卡流量”吧!nload是个很好用的流量监控
2023-06-10

CentOS 6.7下如何搭建Hadoop 2.7.3集群

这篇文章主要介绍了CentOS 6.7下如何搭建Hadoop 2.7.3集群,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Hadoop集群有三种运行模式:单机模式、伪分布模式
2023-06-03

Grafana + Prometheus如何快速搭建监控平台

小编给大家分享一下Grafana + Prometheus如何快速搭建监控平台,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!总体可视化方案Grafana:通过将采
2023-06-15

kubernetes集群如何搭建Zabbix监控平台

本篇内容介绍了“kubernetes集群如何搭建Zabbix监控平台”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、zabbix介绍1.z
2023-07-02

编程热搜

目录