CentOS下搭建cacti监控


一、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

49.221.63.54

客户端

任意网络设备

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  //搭建LAMP环境

[root@localhost/]# yum install -y cacti  net-snmp  net-snmp-utils  rrdtool  //安装cactinet-snmprrdtool

 

启动服务:

[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-0.8.8b/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服务:

 

调整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/include/config.php"

 

wKioL1ej6w-QugILAADMUjwvt4w032.png-wh_50

3web访问cacti并安装

http://ip/cact

 

wKioL1ej6xDwCL32AAImWnyzFBE467.png-wh_50

wKiom1ej6xCgZkTEAADW9eFfTjY937.png-wh_50

wKioL1ej6xGymgduAAK2dNSDim8566.png-wh_50


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

wKiom1ej6xGhNrPHAADAOQDM8DE463.png-wh_50

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

 

wKioL1ej6xLiZWHEAADWh0S3QQs520.png-wh_50

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“

wKiom1ej6xPjCOCJAAFeVRoChHo354.png-wh_50

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

Hostname   写被监控客户机ip

Host Template ucd/net  SNMP Host

SNMP Version Version 2

点右下角的create 

wKioL1ej6xbh7m1iAAZy3CoK-EM316.png-wh_50

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

wKiom1ej6xfRvtI2AAIM-vpfDq4169.png-wh_50

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

wKiom1ej6xnia3mjAAVcebrbFlQ424.png-wh_50

Graph Types: 再选择 Graph Template Based,在下面的框中,选择你要监控的项目,比如Unix- Load Average,在右侧小方块中打对勾,然后点右下角的createwKioL1ej6xvjSpzmAANZjyCnIck420.png-wh_50

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

 

wKiom1ej6xvBxA-TAADOZZ1m_oE141.png-wh_50

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

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

 

wKiom1ej6xzQURdUAAFuj3sPolc181.png-wh_50


 


本文出自 “诺克” 博客,请务必保留此出处http://9840752.blog.51cto.com/9830752/1834617

本页内容版权归属为原作者,如有侵犯您的权益,请通知我们删除。

记一次服务器timewait事件 - 2016-08-22 17:08:07

之前一直没怎么关注过TCP,直到公司这次的事件,这才开始慢慢去研究,去学习TCP的相关知识,中间也尝试了很多方法,走了很多弯路,因此记下这篇文章,方便以后回顾 首先说下网络架构 Nginx和jetty都在同一个服务器,Nginx代理HTTP流量至多个jetty应用,基本情况就是这样 首先我们来看下,为什么会有TIMEWAIT的状态 客户端主动关闭连接时,会发送最后一个ack后,然后会进入TIME_WAIT状态,再停留2个MSL时间,进入CLOSED状态。 也就是说一般timewait只会出现在client
因为都知道安装linux软件包rpm 很好用;但是不能解决软件包的个别依赖关系;所以安装数据包时出现依赖时、yum到可以解决这类数据包依赖关系;而且还能便于管理大量数据包更新的问题;它的特点 、可以同时配置多个资源库(Repository) ,简洁的配置文件(/etc/yum.conf) ,自动解决增加或删除rpm包时遇到的倚赖性问题,保持与RPM数据库的一致性这也是它的优势。因此解决数据包的依赖关系;也是基于服务器和客户端的一种应用。 首先呢 介绍一下YUM 的简单指令: yum info // 查询详
最近在做一个Exchange升级的项目,在部署Exchange Server 2016之前需要将现有环境的Exchange 2010 SP1更新至Exchange Server 2010 SP3RU11或更新的版本中。在更新完SP3+RU11后发现登录OWA时出现异常,在最开始初步以为是RU11的问题,但是卸载后RU11还是一样的问题,所以当时排除是花了比较长的时间的。如下是本次的现象和最后解决的办法供大家参考。 升级至SP3+RU11重启后发现有时可以登录OWA但是点击“新建“邮件时提示 ”无法完成您的
谁说Lync Server 前端不可以使用Windows网络负载平衡实现高可用的?(仅限测试环境) 本章内容有: 1.两台Lync Server安装Windows功能---网络负载平衡 2.配置网络负载平衡 3.DNS记录修改 4.测试故障切换(模拟两种故障,网络故障和服务故障) 5.开始的时候别忘了上一章中的提示,将两台前端Server都进行重启 = = 安装网络负载平衡 两台服务器都需要进行安装 = = 配置网络负载平衡 1)新建群集 2)将LyncFE01先添加到群集中 3)群集IP自己随便填写 4
建立完存储池之后,创建虚拟硬盘的时候,在此虚拟磁盘上创建存储层无法勾选,原因是windows系统识别不出来RAID卡下的硬盘,显示未知如图: 解决办法:powershell 运行在管理员模式下,用下面两条命令(视情况使用其中一条命令即可)。 set-physicaldisk -friendlyname physicaldisk3(看名称自己改) -mediatype hdd (转换磁盘类型为HDD) set-physicaldisk -friendlyname physicaldisk3(看名称自己改)-

CentOS yum源配置小技巧 - 2016-08-22 17:08:05

一、配置yum源 网易(163)yum源是国内最好的yum源之一 ,无论是速度还是软件版本,都非常的不错,将yum源设置为163yum,可以提升软件包安装和更新的速度,同时避免一些常见软件版本无法找到。具体设置方法如下: 1,进入yum源配置目录 #cd/etc/yum.repos.d 2,备份系统自带的yum源 #mvCentOS-Base.repoCentOS-Base.repo.bk 下载163网易的yum源: #wgethttp://mirrors.163.com/.help/CentOS6-Ba

运维监控平台之zabbix详解1 - 2016-08-22 14:08:36

本来是想一篇文章介绍完的,写着写着发现篇幅太长,所以决定还是分两篇来介绍,本次软件所用的版本信息如下(基于LNMP环境),操作系统centos6.7 nginx-1.6.3.tar.gz php-5.6.24.tar.gz mysql-5.5.49-linux2.6-x86_64.tar.gz zabbix-3.0.4.tar.gz (zabbix-3以上版本之支持php5.4以上环境) LNMP环境搭建不再这里说明了,如果不懂的看本人之前写的nginx+php,这里简单介绍下php编译 [root@ce
一、准备工作 CentOS6.4 服务器2台(1台用做IP-SAN存储服务器,1台做流媒体服务器) iSCSITatget 软件 iSCSI Initiator 二、安装iSCSI target软件(IP-SAN服务器) Iscsitarget下载地址为:http://iscsitarget.sourceforge.net[root@iscsi-targetiscsi]#tar-xzvfiscsitarget-1.4.20.1.tar.gz[root@iscsi-targetiscsi]#cdiscsit

Mongodb被动(passive)节点配置 - 2016-08-22 14:08:01

将一个mongodb的普通数据节点修改为passive节点,也就是能同步数据、投票,但是不能成为primary节点。 除了仲裁节点,其他每个节点都有个代表优先权priority的值,我们可以通过设置优先权来决定谁成为primary的权重最大。 MongoDB replica sets中通过设置priority的值来决定优先权的大小,这个值的范围是0--100,值越大,优先权越高。 如果值是0,那么不能成为primay。 通过rs.conf()命令查看出节点列表: 以下为我的实验mongodb集群: PRI

运维监控平台之zabbix详解2 - 2016-08-22 14:08:01

1、Zabbix架构 zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。zabbix能监视各种网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各种问题。 Zabbix的运行架构如下图所示: 2、组件 zabbix由以下几个组件部分构成: 1)、Zabbix Server:负责接收agent发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行; 2)、Database Storage:专用于存储所有配置信息,