1. 安装epel扩展包,并升级ca证书ssl
yum install -y epel-release
yum --disablerepo=epel -y update ca-certificates
如果你想知道为什么,那么一定要参考这个文章,当然不想了解的话就算了
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
如果无法下载,记得要参考下面一篇文章
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)将<Directory /usr/share/cacti/rra>下面的Deny from all 改为 Allow from all
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
进入勾选同意协议,进入下一步
(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)但是往下看的时候,很多标红的地方怎么办呢?
首先第一个标红的是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
(4)更改spine二进制文件的路径
咱们的spine二进制文件路径为/usr/local/spine-1.1.16/bin/spine
(5)选择模板
记得全选即可
12. 更改用户名和密码
之后我们进入登录界面
账号和密码都是
admin
admin
之后我们会被强制要求更改密码,第一行是当前密码,底下两个是新密码,要包括大写小写特殊字符数字,所以我用
Admin#123
Admin#123
13. 配置cacti
(1)
点击Cacti左边的设置选项(Settings)。
点击Poller选项进入配置页。
在Poller Type项后边选择Spine,然后保存
(2)
点击Paths选项进入路径配置页。
设置Spine的路径和配置文件地址/etc/spine.conf,然后保存。
14. 生成localhost的监控图像
/usr/bin/php /usr/share/cacti/poller.php
如果这一步警告信息很多,那是因为你php的时区有误,按照提示更改php的时区为Asia/Chongqing
vim /etc/php.ini
找到如下一行取消注释并改为如下内容
date.timezone="Asia/Chongqing"
然后重启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页面
点击左上角的图像,再选择右上角的预览,刚开始可能会出现如下情况
一般等一会就行了(前提是你前面做的都没错的情况下)多刷新几次
会出现如下图像,但是还没有数据,这时候再等一会就出图了。
以上就是我们实现的对本机的监控,下面我们来实现监控其他机器
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 15639151996@163.com //个人邮箱
更改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
点击右下角的create
点击右上角的*Create Graphs for this Device
在上面的Graph Types中选择SNMP - Interface Statistics,再点击右下角的创建
在上面的Graph Types中选择图形模板基础,选择下方出现的你想监控的图形模板,我在这里就全部选择,然后点击右下角的创建
观察结果,最后我们去观测结果
点击右上角的图形,再点击左上角的预览,这是我们可能得到的是如下图像,不过稍等一下就行了,或者直接去监控机上执行
/usr/bin/php /usr/share/cacti/poller.php
成功!!!
全部结束,这是我做这个实验的的第三遍了,累死了...