博客是我工作的好帮手,遇到困难就来博客找资料
分类: 系统运维
2017-02-20 15:03:33
cacti 是用 php 语言实现的一个软件,它的主要功能是用 snmp 服务获取数据, snmp 需要的变量数据是通过读取 mysql 数据库得到,然后用 rrdtool 储存和更新数据,当用户需要查看数据的时候用 rrdtool 生成图表呈现给用户。
1. Snmp 用来收集数据;
2. Rrdtool 用来存储数据和生成图表;
3. Mysql 用来配合 PHP 程序存储一些变量数据并对变量数据进行调用。
Cacti本身只是一个web界面的管理套件,通过调用Net-SNMP工具来采集检测数据,客户端必须支持SNMP协议。并结合RRDtool(Round Robin Database tool,轮询数据库工具)记录数据并绘制图片,最终,以Web页面的形式展示给管理员用户。
Cacti可以从逻辑上分为三个部分,
第一部分:被检测的对象,也就是客户端。
第二部分:检测平台,也就是服务器端。
第三部分:管理平台。
Cacti采用了两种结构实现功能,
一种是C/S结构,主要是实现服务器到客户端监控;
另外一种就是B/S,主要完成对Cacti平台的管理。
一. 安装apache
准备工作
(1)yum方式安装gcc、gcc-c++
# yum install gcc gcc-c++ -y
(2)安装pcre
pcre下载地址:
#tar zxf pcre-8.35.tar.gz
#cd pcre-8.35
#./configure prefix=/usr/local/pcre
#make && make install
(3)安装apr和apr-util
apr和apr-unit下载地址:
1)解压文件
#tar zxf apr-1.5.0.tar.gz
#tar zxf apr-util-1.5.3.tar.gz
#tar zxf httpd-2.4.9.tar.gz
2)将apr和apr-util拷到http的srclib目录下,并去掉版本号
#cp -r apr-1.5.0 httpd-2.4.9/srclib/apr
#cp -r apr-util-1.5.3 httpd-2.4.9/srclib/apr-util
3)编译安装
安装apr
#cd httpd-2.4.9/srclib/apr
#./configure --prefix=/usr/local/apr
#make && make install
安装apr-util
#cd /root/httpd-2.4.9/srclib/apr-util/
#./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr/
#make && make install
2.正式安装apache
Apache下载地址:
#cd httpd-2.4.9
#./configure --prefix=/usr/local/apache --with-apr=/usr/local/apr/ --with-apr-util=/usr/local/apr-util/ --with-pcre=/usr/local/pcre/
#make && make install
启动apache服务
#service httpd start
安装成功,启动httpd服务并加入开机启动
#chkconfig httpd on
二. 安装mysql
1.准备工作
(1)yum方式安装ncurses-devel
#yum install ncurses-devel –y
(2)安装cmake
cmake下载地址:
#tar zxf cmake-3.0.0.tar.gz
#cd cmake-3.0.0
#./configure
#make && make install
2.创建mysql的安装目录及数据库存放目录
#mkdir /usr/local/mysql/date -pv
/usr/local/mysql/ //mysql安装目录
/usr/local/mysql/data //存在数据库
3.创建mysql用户和用户组
#groupadd mysql
#useradd -r -g mysql mysql
useradd [option] username
[option]:
-d<登入目录> 指定用户登入时的目录。
-g<群组> 初始群组。
-G<群组> 非初始群组。
-m 自动创建用户的家目录。
-M 不要创建用户的家目录。
-N 不要创建以用户名称为名的群组。
-s 指定用户登入后所使用的shell。
-c comment 给新用户添加备注
-d home_dir 为主目录指定一个名字(如果不想用登录名作为主目录名的话)
-e expire_date 用YYYYY-MM-DD格式指定一个账户过期的日期
-f inactive_days 指定这个帐户密码过期后多少天这个账户被禁用;
0表示密码一过期就立即禁 用,-1表示禁用这个功能
-k 必须和-m一起使用,将/etc/skel目录的内容复制到用户的HOME目录
-n 创建一个同用户登录名同名的新组
-r 创建系统账户
-p passwd 为用户账户指定默认密码
-s shell 指定默认登录shell
-u uid 为账户指定一个唯一的UID
4.源码方式安装mysql
Mysql下载地址:
#tar zxf mysql-5.6.17.tar.gz
#cd mysql-5.6.17
#cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_INNOBASE_STORAGE_ENGINE=1 -DMYSQL_TCP_PORT=3306 -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock -DWITH_DEBUG=0
#make && make install
参数说明:
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql //安装目录
-DMYSQL_DATADIR=/usr/local/mysql/data //数据库存放目录
-DMYSQL_TCP_PORT=3306 //端口号
-DENABLED_LOCAL_INFILE=1 //允许从本地导入数据
5.配置mysql
(1)设置目录权限
#chown mysql:mysql /usr/local/mysql/ -R
(2)初始化mysql数据库
#cd /usr/local/mysql/
#./scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/ --basedir=/usr/local/mysql/
(3)复制mysql服务启动脚本
#cp ./support-files/mysql.server /etc/init.d/mysqld
(4)配置环境变量
#vim /etc/profile
添加:
PATH=$PATH:/usr/local/mysql/bin:/usr/local/mysql/lib
重新加载重启生效
#source /etc/profile
(5)修改mysql主配置文件/etc/my.cnf
全部内容如下:
6.启动mysql
(1)开启守护进程,生成pid
#./mysqld_safe &
(2)启动mysql
#service mysqld restart
7.设置mysql管理员密码
#./mysqladmin password "123456" -u root
三. 安装PHP
准备工作
1)安装zlib
zlib下载地址:
#tar zxf zlib-1.2.8.tar.gz
#cd zlib-1.2.8
#./configure --prefix=/usr/local/zlib
#make && make install
2)安装libpng
libpng下载地址:
注意:这里建议下载libpng-1.5.18版本,因为libpng与zlib存在版本兼容的问题,如果版本不合适,会make的时报错
已知 zlib-1.2.8和libpng-1.6.10之间就存在这种问题, zlib-1.2.8和libpng-1.5.18可以正常安装,有篇文章对此问题进行了一些描述
#tar zxf libpng-1.5.18.tar.gz
#cd libpng-1.5.18
#./configure --prefix=/usr/local/libpng
#make && make install
编译的时候后面加上--with-zlib-prefix=/usr/local/zlib/,还是提示相同的错误
明明已经安装了zlib,为什么提示zlib没有安装,原来是没有安装zlib-devel,下面我们使用yum方式安装zlib-devel
#yum install zlib-devel
下面编译就成功了
#./configure --prefix=/usr/local/libpng --with-zlib-prefix=/usr/local/zlib/
再安装
3)安装freetype
freetype下载地址:
#cd freetype-2.5.3
#./configure --prefix=/usr/local/freetype
#make && make install
4)安装jpeg
jpeg下载地址:
#tar zxf jpegsrc.v9.tar.gz
#cd jpeg-9/
#./configure --prefix=/usr/local/libjpeg
#make && make install
5)yum方式安装fontconfig、gd、libxml2*、libjpeg-devel
# yum install fontconfig gd –y
# yum install libxml2* libjpeg-devel –y
2.正式安装PHP
PHP下载地址:wget
#tar zxf php-5.5.14.tar.gz
#cd php-5.5.14
#./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs --with-gd --with-mysql=/usr/local/mysql/ --with-zlib-dir=/usr/local/zlib/ --with-png-dir=/usr/local/libpng/ --enable-gd-native-ttf --with-ttf --enable-gd-jis-conv --enable-mbstring --enable-sockets --enable-xml --disable-fileinfo
#make && make install
最后建立一个软连接
ln -s /usr/local/php/bin/* /usr/local/bin/
四. 安装rrdtool
1.准备工作
(1)yum方式安装cairo-devel、pango、pango-devel、libpng-devel、libart_lgpl-devel、intltool、freetype-devel
#yum install cairo-devel pango pango-devel libpng-devel libart_lgpl-devel intltool freetype-devel –y
(2)yum方式安装perl-ExtUtils-CBuilder、perlExtUtils-MakeMaker
# yum install perl-ExtUtils-CBuilder perlExtUtils-MakeMaker –y
2.正式安装rrdtool
rrdtool下载地址:
#tar zxf rrdtool-1.4.5.tar.gz
#cd rrdtool-1.4.5
#./configure --prefix=/usr/local/rrdtool --disable-tcl
#make && make install
2.增加链接
ln -s /usr/local/rrdtool/bin/* /usr/local/bin/
五. 安装net-snmp
(1)yum方式安装net-snmp
# yum install net-snmp* -y
(2)配置net-snmp(主配置文件/etc/snmp/snmpd.conf)
netstat -an |grep snmp
(4)验证是否有数据
1)localhost
# snmpwalk -v 2c -c public localhost
2)本机ip测试
# snmpwalk -v 2c -c public 192.81.128.66
192.81.128.66就是被监控机的IP(这里测试的是本机,所以就是本机IP)
六. 安装cacti
cacti下载地址:
1. 解压cacti后,把cacti的目录移到httpd里存放网页的htdocs目录,并去掉版本号
#tar zxf cacti-0.8.7h.tar.gz
#mv cacti-0.8.7h /usr/local/apache/htdocs/cacti
2.增加cacti用户,并修改目录权限
cd /usr/local/apache/htdocs
useradd catic
chown -R cacti.cacti ./
3.root身份登陆mysql,新建数据并授权
mysql -uroot -p
> grant all on cacti.* to cacti@'localhost' identified by '123456';
> flush privileges;
4.导入数据库
cd /usr/local/apache/htdocs/cacti
# /sur/local/mysql/bin/mysql -u cacti -p123456 cacti < cacti.sql
vim include /config.php
这里有cacti连接使用的数据库类型,用户名,密码信息,按照自己的需要进行配置
下载解压后只取两个文件
1、 PHP采集脚本:
cp percona-monitoring-plugins-1.1.6/cacti/scripts/ss_get_mysql_stats.php /var/www/html/cacti/scripts/
chmod +x ss_get_mysql_stats.php
在被监控端mysql服务器上授权
mysql> grant process,super on *.* to'cacti'@'%' identified by 'cacti';
注意:MySQL 5.1.23和更旧版本中采集InnoDB图形需要SUPER权限。
在MySQL 5.1.24及更高版本中,所需的权限是PROCESS而不是SUPER。(官方)
[root@server2 mnt]# tar zxf cacti-0.8.8h.tar.gz
[root@server2 mnt]# yum install rrdtool php-mysql mysql-serverhttpd -y
(安装必要环境)
[root@server2 mnt]# mv cacti-0.8.8h /var/www/html/
(将cacti 移动到http目录下)
[root@server2 mnt]# cd /var/www/html/
[root@server2 html]# ln -s cacti-0.8.8h/ cacti
(建立软链接,方便输入查找)
[root@server2 html]# cd /mnt
[root@server2 mnt]# yum install php-snmp-5.3.3-26.el6.x86_64.rpm
[root@server2 mnt]#/etc/init.d/mysqld start
[root@server2 mnt]#mysql_secure_installation
(设置root 账户和密码,其他选项,一直输入 y 继续进行)
[root@server2 cacti]# cd/var/www/html/cacti/
[root@server2 cacti]#mysqladmin -padol create cacti
(创建cacti这个库)
[root@server2 cacti]# mysql -padol cacti < cacti.sql
(将cacti.sql导入cacti 库)
[root@server2 cacti]# mysql -padol -e "grant all on cacti.* totest@localhost identified by 'adol';"(创建用户,给予cacti.*权限)
[root@server2 cacti]# cdinclude/
[root@server2 cacti]# vimconfig.php