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

[经验分享] CentOS6.8 install Cacti 0.8.8g

[复制链接]
YunVN网友  发表于 2019-4-17 17:25:09 |阅读模式
  Centos6.8 Cacti 0.8.8g
一、Cacti简介

  • cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用rrdtool生成图表呈现给用户。因此snmp和rrdtool是cacti的关键。Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成。
  • Mysql配合PHP程序存储一些变量数据并对变量数据进行调用,如:主机名、主机ip、snmp团体名、端口号、模板信息等变量。
  • snmp抓到数据不是存储在mysql中,而是存在rrdtool生成的rrd文件中(在cacti根目录的rra文件夹下)。rrdtool对数据的更新和存储就是对rrd文件的处理,rrd文件是大小固定的档案文件(RoundRobinArchive),它能够存储的数据笔数在创建时就已经定义。


  二、Cacti工作原理
Cacti操作可以分为以下三部分:

  1.Data Retrieval
Cacti首先要做的工作就是收集数据,cacti使用Poller(轮询器)收集数据。Poller是操作系统scheduler的扩展,如在类Unix系统中的crontab。现在的IT设施中会有许多不同的设备,如服务器、网络设备等,cacti主要使用SNMP协议来从远端的设备上收集数据,所有可以使用SNMP协议的设备都可以被cacti监控。
2.Data Storage
存储收集到的数据有许多方法,可以使用数据库、平面文件等,cacti使用的是RDDTool。RRD是Round Robin Database(环形数据库)的缩写,RRD用来存储和显示时间序列数据,如网络带宽、机房温度、服务器负载等,RRD使用非常紧凑的方式存储数据,数据不会随着时间的推移而增大,RRD还可以生成美观的图形。这些特性使得cacti没有存储需求。RRD也做一席位其他的工作,如RRD会将原始数据与已整合的数据进行合并,以使得历史数据的存储节省空间,RRD支持的整合功能包括:AVERAGE, MAXIMUM, MINIMUM和LAST。
3.Data Presentation
Cacti最大的一个特点是内置了RRDTool画图功能,将其与通用的web服务器相结合,可以实现在任意平台上使用浏览器就可以查看监控画面。
  Homepage: http://www.cacti.net/
plugins:http://docs.cacti.net/plugins
templates:http://docs.cacti.net/templates
  三、安装cacti
1.关闭防火墙和selinux
[root@localhost ~]#service iptables stop
[root@localhost ~]#chkconfig iptables off
[root@localhost~]#vi /etc/sysconfig/selinux
  2.安装cacti依赖的软件
[root@localhost~]#yum -y install mysql mysql-server mysql-devel httpd php gd php-gd php-pdo php-snmp php-xml php-mysql lm_sensors net-snmp net-snmp-utils net-snmp-libs net-snmp-devel rrdtool rrdtool-devel  perl-DBI perl-rrdtool perl-DBD-MySQL
  3.snmpd配置
[root@localhost ~]#vim /etc/snmp/snmpd.conf
第41行:将 com2sec notConfigUser default public 中的 "default" 改为 "127.0.0.1"
第62行:将 access notConfigGroup "" any noauth exact systemview none none 中的 "systemview" 改为 "all"
第85行:将 #view all include .1 80 这一行前面的#号去掉
  4.启动服务
[root@localhost ~]#service snmpd start
[root@localhost ~]#service httpd start
[root@localhost ~]#service mysqld start
  5.安装并配置cacti
[root@localhost ~]#wget http://www.cacti.net/downloads/cacti-0.8.8g.tar.gz
[root@localhost ~]#tar -zxvf cacti-0.8.8g.tar.gz
[root@localhost ~]#mv cacti-0.8.8g/ /var/www/html/
[root@localhost ~]#chown root:root -R  /var/www/html/

  6.设置mysql数据库
[root@localhost ~]#mysql -uroot -p
mysql>create database cacti character set utf8;
mysql>grant all privileges on cacti.* to "cacti"@"localhost" identified by 'cacti';
mysql> flush privileges;
mysql>use cacti;
mysql>source /var/www/html/cacti/cacti.sql;
mysql>exit
  7.配置cacti
[root@localhost ~]#vim /var/www/html/include/config.php
$database_type = "mysql";
$database_default = "cacti";
$database_hostname = "localhost";
$database_username = "cacti";
$database_password = "cacti";
$database_port = "3306";
  [root@localhost ~]#vim /var/www/html/include/global.php
$database_type = "mysql";
$database_default = "cacti";
$database_hostname = "localhost";
$database_username = "cacti";
$database_password = "cacti";
$database_port = "3306";
$database_ssl = false;
  / Default session name - Session name must contain alpha characters /
$cacti_session_name = "Cacti";
  / define default url path /
$url_path = "/";
  8.修改rra目录权限
[root@localhost ~]#mkdir /var/www/html/cache #创建缓存目录
[root@localhost ~]#chown -R apache:apache /var/www/html/rra/ log/ cache/ #根据httpd服务启动用户修改
  9.添加任务计划
具体多长时间让cacti生成一次监控图表自己决定,这里以cacti的默认时间5分钟生成一次为例,默认的采集方式是cmd.php
[root@localhost ]# touch /etc/cron.d/cacti
[root@localhost ]# vim /etc/cron.d/cacti

  10.配置好之后重启输入 http://ip/Prot new install , next...
此处如果没有红色字体"NOT FOUND"字样则算通过,finish即可,如果有则要手动指定路径,finish之后就出现cacti的登录界面,默认用户名和密码都是admin.login之后cacti强制要求更改密码,改完保存即可;到这里前期的安装工作就算全部结束了,之后就是配置监控。
  四、Cacti优化之spine轮询器
由于效率的原因,在需要大量采集数据时,如果使用自带的cmd.php轮询器会比较慢,1分钟1次的采集频率可能无法完成轮询所有的被监控的机器。为了解决效率问题,Cacti官方也推出spine,采用多线程的方式高效的轮询。
  1.解决依赖关系
[root@localhost ~]# yum -y install net-snmp-devel openssl-devel mysql-devel help2man
  2.安装spine,下载的版本最好与cacti版本一致
[root@localhost ~]# wget https://www.cacti.net/downloads/spine/cacti-spine-0.8.8g.tar.gz
[root@localhost ~]# tar xf cacti-spine-0.8.8g.tar.gz
[root@localhost ~]# cd cacti-spine-0.8.8g
[root@localhost cacti-spine-0.8.8g]# ./configure
[root@localhost cacti-spine-0.8.8g]# make -j 2 && make install
  3.提供配置文件
[root@localhost ~]# cp /usr/local/spine/etc/spine.conf.dist /etc/spine.conf
[root@localhost ~]# vim /etc/spine.conf
DB_Host localhost
DB_Database cacti
DB_User cacti
DB_Pass cacti
DB_Port 3306
如果忘记了数据库配置可以参考:cacti/include/config.php
  4.测试
[root@localhost ~]# /usr/local/spine/bin/spine --help
SPINE 0.8.8g  Copyright 2002-2016 by The Cacti Group
  5.在cacti的WEB页面进行设置spine的路径
Console -> Configureation -> Settings -> Alternate Poller Path -> Spine Poller File Path
输入spine的路径:默认安装在/usr/local/spine/bin/spine

  6.修改Cacti默认的Poller Types
  Console -> Cacti Settings -> Poller -> Poller Type
在下拉框中,选择spine, 然后记得“Save”

  注意:Spine不必为其添加计划任务,Cacti well spawn Spine every 5 minutes instead of cmd.php
而poller.php需要定义计划任务去执行,然后poller.php再去调度数据收集方法。
  7.解决在图像上方无法显示中文字符
  解决方法:
  安装中文语言包
  yum install -y wqy-zenhei-fonts
  或者
  yum install dejavu-lgc-sans-fonts -y
  yum groupinstall "Fonts" -y
  8.编辑 functions.php 文件(系统安装环境不同,目录位置不同,直接使用find查找到Cacti根目录下的lib下functions.php文件进行编辑即可)

  在倒数第二行插入:setlocale(LC_CTYPE,"zh_CN.UTF-8");
  添加完成后刷新浏览器即可

  9.安装插件
  首先下载插件解压到plugins目录

  安装 rsyslog
  [root@localhost ]# yum install   rsyslog  rsyslog-mysql -y
  创建syslog数据库
  mysql> create database syslog character set utf8;

  授权
  mysql> grant all privileges on syslog.* to "syslog"@"localhost" identified by "password";
  mysql> flush privileges;
  编辑配置文件
  vim syslog/config.php
  32         $syslogdb_type     = 'mysql';
33         $syslogdb_default  = 'syslog';
34         $syslogdb_hostname = 'localhost';
35         $syslogdb_username = 'syslog';
36         $syslogdb_password = 'password';
37         $syslogdb_port     = 3306;
  编辑rsyslog.conf
  vim /etc/rsyslog.conf
  倒数第二行插入
  . @@localhost:514
$ModLoad imudp.so
$UDPServerRun 514
$ModLoad ommysql
$template cacti_syslog,"INSERT INTO syslog_incoming(facility, priority, date, time, host, message) values ('%syslogfacility-text%', '%syslogpriority-text%', '%timereported:::date-mysql%', '%timereported:::date-mysql%', '%HOSTNAME%', '%msg%')", SQL
. >localhost,syslog,syslog,password;cacti_syslog
  重启 rsyslog 服务
  service rsyslog restart







运维网声明 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-828398-1-1.html 上篇帖子: CentOS内存占满后释放缓存 下篇帖子: Centos6下载MySQL-506217036的博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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