cacti监控工具

1. 安装epel扩展包,并升级ca证书ssl

yum install -y epel-release

yum --disablerepo=epel -y update ca-certificates

如果你想知道为什么,那么一定要参考这个文章,当然不想了解的话就算了

认识epel

2. 安装LAMP环境

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

3. 安装cacti和snmp

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

4. 安装依赖包

yum install -y net-snmp-devel help2man

5. 下载cacti-spine

cd /usr/local/src

wget https://www.cacti.net/downloads/spine/cacti-spine-1.1.16.tar.gz


如果无法下载,记得要参考下面一篇文章

解决wget无法下载https


6. 解压、编译安装cacti-spine

cd /usr/local/src

tar -zxvf cacti-spine-1.1.16.tar.gz

cd cacti-spine-1.1.16

如果没有gcc编译器,记得要安装gcc

yum install -y gcc

./configure --prefix=/usr/local/spine-1.1.16 --with-snmp=/usr/include/net-snmp/ --with-mysql 

make && make install

7. 启动httpd,snmpd,mysqld服务

/etc/init.d/mysqld start

/etc/init.d/httpd start

/etc/init.d/snmpd start

当然也可以用如下命令启动

service mysqld start

service httpd start

service snmpd start

8. 创建cacti数据库,数据库用户和数据库密码,并导入cacti的表

mysql -uroot -e "create database cacti"

mysql -uroot -e "grant all on cacti.* to 'cacti'@'127.0.0.1' identified by 'cacti';"

mysql -uroot cacti < /usr/share/doc/cacti-1.1.16/cacti.sql

当然数据库名字,用户名字和密码都可以自定义

第三步如果找到cacti.sql可以尝试搜索cacti的位置

find / -type f -name "cacti.sql"

9. 更改配置文件

9.1 更改httpd配置文件(2个地方需要更改)

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

(1)将#http2.2下面的Deny from all 改为 Allow from all


第一个修改点

(2)将下面的Deny from all 改为 Allow from all


cacti监控工具_第1张图片
第二个修改点

9.2 更改cacti的配置文件

vim /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;

这部分内容可以不更改,想更改的话记得取消注释,改成如下内容,

$rdatabase_type    = 'mysql';

$rdatabase_default  = 'cacti';

$rdatabase_hostname = '127.0.0.1';

$rdatabase_username = 'cacti';

$rdatabase_password = 'cacti';

$rdatabase_port    = '3306';

$rdatabase_ssl      = false;

9.3 更改spine配置文件

spine是源码安装的。他的配置文件在/usr/local/spine-1.1.16/etc/spine.conf.dist

我们要将其改名并移动到/etc下

cd /usr/local/spine-1.1.16/etc/

mv spine.conf.dist  /etc/spine.conf

vim /etc/spine.conf

这都和上面差不多,要和自己数据库名字密码想匹配

DB_Host                127.0.0.1

DB_Database            cacti

DB_User                cacti

DB_Pass                cacti

DB_Port                3306

RDB_Host                127.0.0.1

RDB_Database            cacti

RDB_User                cacti

RDB_Pass                cacti

RDB_Port                3306

10. 重启服务

service mysqld restart

service httpd restart

service snmpd restart

11. 用浏览器访问cacti的安装,在windows浏览器中输入服务器ip/cacti即可进入cacti安装界面

http://10.2.3.110/cacti


cacti监控工具_第2张图片

进入勾选同意协议,进入下一步

cacti监控工具_第3张图片


(1)标红的地方出现Error

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.

大概就是说你刚才建的cacti账户没有对mysql数据库的time_zone_name表select的权限,所以授权就行了

进入mysql,一般新装的mysql没有密码

mysql -uroot

mysql>grant select on mysql.time_zone_name to cacti@localhost identified by 'cacti'

注意要和自己的数据库用户和密码对应

(2)错误2

ERROR: Your MySQL TimeZone database is not populated. Please populate this database before proceeding.

解决方法:

mysql_tzinfo_to_sql /usr/share/zoneinfo/ | mysql -u root  mysql


重启下mysqld服务

service  mysqld restart

回到网页刷新即可

(3)但是往下看的时候,很多标红的地方怎么办呢?


cacti监控工具_第4张图片

首先第一个标红的是mysql的版本问题,不用理会,其他的可以通过修改mysql的配置文件来解决。

vim /etc/my.cnf

将里面的内容更改为如下图

[mysqld]

datadir=/var/lib/mysql

socket=/var/lib/mysql/mysql.sock

user=mysql

# Disabling symbolic-links is recommended to prevent assorted security risks

symbolic-links=0

max_heap_table_size=1567M

max_allowed_packet=16777216

join_buffer_size=64M

tmp_table_size=64M

innodb_file_per_table=1

innodb_buffer_pool_size=246M

innodb_doublewrite=0

innodb_additional_mem_pool_size=80M

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

cacti监控工具_第5张图片

(4)更改spine二进制文件的路径


cacti监控工具_第6张图片

咱们的spine二进制文件路径为/usr/local/spine-1.1.16/bin/spine

(5)选择模板

记得全选即可


cacti监控工具_第7张图片

12. 更改用户名和密码

之后我们进入登录界面

账号和密码都是

admin

admin

之后我们会被强制要求更改密码,第一行是当前密码,底下两个是新密码,要包括大写小写特殊字符数字,所以我用

Admin#123

Admin#123

cacti监控工具_第8张图片

13. 配置cacti

(1)

点击Cacti左边的设置选项(Settings)。

点击Poller选项进入配置页。

在Poller Type项后边选择Spine,然后保存


cacti监控工具_第9张图片

(2)

点击Paths选项进入路径配置页。

设置Spine的路径和配置文件地址/etc/spine.conf,然后保存。

cacti监控工具_第10张图片

14. 生成localhost的监控图像

/usr/bin/php /usr/share/cacti/poller.php

cacti监控工具_第11张图片
时区警告

如果这一步警告信息很多,那是因为你php的时区有误,按照提示更改php的时区为Asia/Chongqing

vim /etc/php.ini

找到如下一行取消注释并改为如下内容

date.timezone="Asia/Chongqing"


cacti监控工具_第12张图片

然后重启httpd

service httpd restart

再次生成图像,就不会有警告信息

/usr/bin/php /usr/share/cacti/poller.php

我们要讲上面这句生成图像的命令加入到计划任务中去,每五分钟执行一次

crontab -e 

*/5 * * * * /usr/bin/php /usr/share/cacti/poller.php

启动计划任务并设为开机自启

service crond restart

chkconfig crond  on

之后我们去web页面

点击左上角的图像,再选择右上角的预览,刚开始可能会出现如下情况

cacti监控工具_第13张图片

一般等一会就行了(前提是你前面做的都没错的情况下)多刷新几次


cacti监控工具_第14张图片

会出现如下图像,但是还没有数据,这时候再等一会就出图了。


cacti监控工具_第15张图片

以上就是我们实现的对本机的监控,下面我们来实现监控其他机器


15. 换一台客户机,安装snmp

yum install -y net-snmp lm_sensors

修改配置文件snmpd.conf

vim /etc/snmp/snmpd.conf

更改1:

#syslocation Unknown (edit /etc/snmp/snmpd.conf)     

#syscontact Root(configure /etc/snmp/snmp.local.conf)

变为

syslocation 10.2.3.111 //本机ip

syscontact Root [email protected] //个人邮箱

更改2:

#view all    included  .1                              80

变为

view all    included  .1                              80

找到如下相似内容并更改为:

#      group          context sec.model sec.level prefix read  write  notif

access  notConfigGroup ""      any      noauth    exact  all    none none

更改4:

#view mib2  included  .iso.org.dod.internet.mgmt.mib-2 fc

变为

view mib2  included  .iso.org.dod.internet.mgmt.mib-2 fc

更改5:

view    systemview    included  .1.3.6.1.2.1.1

变为

view    systemview    included  .1.3.6.1.2.1

启动snmpd服务

service snmpd start

16. 在浏览器管理后台增加主机设备

在左边选择       管理->设备->右上角加号(添加)

描述    随便自定义         test2

主机名       填写要监控的ip地址        10.2.3.111

设备模板         选择             Net-SNMP Device

SNMP版本           选择               Version 2


cacti监控工具_第16张图片

点击右下角的create

cacti监控工具_第17张图片

点击右上角的*Create Graphs for this Device

在上面的Graph Types中选择SNMP - Interface Statistics,再点击右下角的创建

在上面的Graph Types中选择图形模板基础,选择下方出现的你想监控的图形模板,我在这里就全部选择,然后点击右下角的创建

cacti监控工具_第18张图片

观察结果,最后我们去观测结果

点击右上角的图形,再点击左上角的预览,这是我们可能得到的是如下图像,不过稍等一下就行了,或者直接去监控机上执行

/usr/bin/php /usr/share/cacti/poller.php

cacti监控工具_第19张图片

成功!!!

cacti监控工具_第20张图片

全部结束,这是我做这个实验的的第三遍了,累死了...

你可能感兴趣的:(cacti监控工具)