centos 搭建cacti监控以及常见故障解决方案

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云防火墙,500元 1000GB
简介:

      CentOS搭建Cacti监控平台以及故障解决

准备环境:

一、配置防火墙,开启80端口、3306端口

vi/etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp--dport 80 -j ACCEPT(允许80端口通过防火墙)

-A INPUT -m state --state NEW -m tcp -p tcp--dport 3306 -j ACCEPT(允许3306端口通过防火墙)

特别提示:很多哥们把这两条规则添加到防火墙配置的最后一行,导致防火墙启动失败,正确的应该是添加到默认的22端口这条规则的下面

添加好之后防火墙规则如下所示:

*filter

:INPUT ACCEPT[0:0]

:FORWARD ACCEPT[0:0]

:OUTPUT ACCEPT[0:0]

-A INPUT -mstate --state ESTABLISHED,RELATED -j ACCEPT

-A INPUT -p icmp-j ACCEPT

-A INPUT -i lo-j ACCEPT

-A INPUT -mstate --state NEW -m tcp -p tcp --dport 22 -j ACCEPT

-A INPUT -mstate --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

-A INPUT -mstate --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

-A INPUT -jREJECT --reject-with icmp-host-prohibited

-A FORWARD -jREJECT --reject-with icmp-host-prohibited

COMMIT

/etc/init.d/iptablesrestart#最后重启防火墙使配置生效

二、关闭SELINUX

vi/etc/selinux/config

#SELINUX=enforcing#注释掉

SELINUX=disabled#增加

:wq保存,关闭

shutdown -r now#重启系统

三、系统约定

软件源代码包存放位置:/usr/local/src

源码包编译安装位置:/usr/local/软件名字

四、下载软件包

http://wwwNaNake.org/files/v2.8/cmake-2.8.7.tar.gz

ftp://mcrypt.hellug.gr/pub/crypto/mcrypt/libmcrypt/libmcrypt-2.5.7.tar.gz

http://mirror.bit.edu.cn/apache/apr/apr-1.4.6.tar.gz

http://mirror.bit.edu.cn/apache/apr/apr-util-1.4.1.tar.gz

五、安装编译工具及库文件(使用CentOS yum命令安装)

yum install make autoconfautomake gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel gdkernel keyutilspatchperl kernel-headers compat* mpfr cpp glibc libgomp libstdc++-devel pplcloog-ppl keyutils-libs-devel libcom_err-devel libsepol-devel libselinux-develkrb5-devel zlib-devel libXpm* freetype libjpeg* libpng* php-common php-gdncurses* libtool* libxml2 libxml2-devel patch

安装步骤

以下是用putty工具远程登录到服务器,在命令行下面操作的

1)安装libmcrypt

cdlibmcrypt-2.5.7./configuremake && make install

ldconfigcd libltdl/./configure--enable-ltdl-install make && make install

2)安装cmake./configure --prefix=/usrmake && make install

3)安装apryum-yremoveapr

./configure--prefix=/usr/local/webserver/aprmake && make install

4)安装apr-util

./configure--prefix=/usr/local/webserver/apr-util--with-apr=/usr/local/webserver/apr/bin/apr-1-config

1、安装mysql

#Nginxyum -yinstall pcre-develzlib-devel

第二步:添加MYSQL安装用户

groupaddmysql

useradd -gmysqlmysql -s /bin/false

第三步:编译和安装

cd mysql-5.5.21

cmake \

-DCMAKE_INSTALL_PREFIX=/usr/local/webserver/mysql\

-DMYSQL_DATADIR=/user/local/webserver/mysql/data\

-DSYSCONFDIR=/etc\

-DEXTRA_CHARSETS=all\

-DDEFAULT_CHARSET=utf8\

-DDEFAULT_COLLATION=utf8_general_ci\

-DWITH_INNOBASE_STORAGE_ENGINE=1\

-DWITH_ARCHIVE_STORAGE_ENGINE=1\

-DWITH_BLACKHOLE_STORAGE_ENGINE=1\

-DWITH_FEDERATED_STORAGE_ENGINE=1\

-DWITH_PARTITION_STORAGE_ENGINE=1\

-DWITH_PERFSCHEMA_STORAGE_ENGINE=1\

-DMYSQL_UNIX_ADDR=/usr/local/webserver/mysql/tmp/mysqld.sock\

-DMYSQL_TCP_PORT=3306\

-DWITH_DEBUG=0 \

-DENABLED_LOCAL_INFILE=1

make&& make install

第四步:设置mysql

#support-files目录中有五个配置信息文件(这里很重要,一定要根据自己的内存复制对应的cnf文件,否则mysql始终起不来)

#my-small.cnf (内存<=64M)#my-medium.cnf (内存 128M)#my-large.cnf (内存 512M)

#my-huge.cnf (内存 1G-2G)#my-innodb-heavy-4G.cnf (内存 4GB)

cp ./support-files/my-huge.cnf /etc/my.cnf

vi /etc/my.cnf

# [mysqld] 段增加

datadir = /usr/local/webserver/mysql/data

wait-timeout =30

max_connections= 512

# [mysqld] 段修改

max_allowed_packet= 16M

第五步:设置权限

chown -R root.mysql.

chown -Rmysql.mysql data

第六步:生成新的mysql授权表

//利用mysql_install_db脚本生成新的mysql授权表

cd/usr/local/webserver/mysql/scripts

./mysql_install_db--user=mysql --basedir=/usr/local/webserver/mysql--datadir=/usr/local/webserver/mysql/data

第七步:添加mysql server到系统服务

cpsupport-files/mysql.server /etc/init.d/mysqld#Mysql加入系统启动

chmod 755/etc/init.d/mysqld#增加执行权限

chkconfigmysqldon#加入开机启动

vi/etc/init.d/mysqld #编辑

basedir =/usr/local/webserver/mysql#MySQL程序安装路径

datadir =/usr/local/webserver/mysql/data#MySQl数据库存放目录

service mysqldstart#启动

第八步:mysql服务加入系统环境变量

vi /etc/profile#mysql服务加入系统环境变量:在最后添加下面这一行

exportPATH=$PATH:/usr/local/webserver/mysql/bin

#使环境变量立即生效:source /etc/profile

下面这两行把myslq的库文件链接到系统默认的位置,这样你在编译类似PHP等软件时可以不用指定mysql的库文件地址。

//设置软连接使mysql,mysqldump,mysqladmin这三个bin命令能在shell中直接运行

ln -s/usr/local/webserver/mysql/include/mysql /usr/bin

ln -s/usr/local/webserver/mysql/bin/mysqldump /usr/bin

ln -s/usr/local/webserver/mysql/bin/mysqladmin /usr/bin

第九步:设置密码

mysqladmin-uroot password "ellisqin"

2、安装apache2

./configure--prefix=/usr/local/webserver/apache--with-apr=/usr/local/webserver/apr --with-apr-util=/usr/local/webserver/apr-util--enable-static-support--enable-mods-shared=most--enable-speling--enable-forward --enable-ssl--with-ssl--enable-cache-disk --enable-cgid--enable-module=so --with-mysql=/usr/local/webserver/mysql--sysconfdir=/usr/local/lamp/etc

# /usr/local/webserver/apache/bin/apachectl-k start#启动

# vi /usr/local/webserver/apache/conf/httpd.conf#编辑配置文件

找到:#ServerNamewww.example.com:80修改为:ServerName www.pphc.com:80

找到:DirectoryIndex index.html修改为:DirectoryIndex index.html index.php

找到:Options Indexes FollowSymLinks修改为:Options FollowSymLinks#不显示目录结构

找到AllowOverride None 修改为:AllowOverride All#开启apache支持伪静态,有两处都做修改

LoadModulerewrite_modulemodules/mod_rewrite.so#取消前面的注释,开启apache支持伪静态

vi/etc/profile#添加apache服务系统环境变量

在最后添加下面这一行

exportPATH=$PATH:/usr/local/webserver/apache/bin

cp/usr/local/webserver/apache/bin/apachectl /etc/init.d/httpd#apache加入到系统启动

vi/etc/init.d/httpd#编辑文件

#!/bin/sh下面添加以下两行

#chkconfig:234510 90

#descrption:Activates/DeactivatesApache Web Server

chowndaemon.daemon-R /usr/local/webserver/apache/htdocs#更改目录所有者

chmod700 /usr/local/webserver/apache/htdocs-R #更改apache网站目录权限

chkconfighttpdon#设置开机启动

3、安装php

yum install libjpeg-devel net-snmp net-snmp-devel net-snmp-utils gmpgmp-devel php-mysql* freetype* object* bzip2* gd-devel libpng-develfreetype-deve l libxml2-devel curl-devel

ln -s /usr/local/lib/libiconv.so.2 /usr/lib64/

./configure--prefix=/usr/local/webserver/php--with-apxs2=/usr/local/webserver/apache/bin/apxs--with-mysql=/usr/local/webserver/mysql--with-gd--with-freetype-dir--with-jpeg-dir--with-png-dir --enable-sockets

#makemakeinstall

cpphp.ini-production /usr/local/webserver/php/etc/php.ini#复制php配置文件到安装目录

ln -s/usr/local/webserver/php/bin/*/usr/local/bin#创建配置文件软链接

vi /usr/local/webserver/php/etc/php.ini#编辑

找到:;open_basedir =

修改为:open_basedir= .:/tmp/#防止php木马跨站,重要!!

#列出PHP可以禁用的函数,如果某些程序需要用到这个函数,可以删除,取消禁用。

找到:;date.timezone =

修改为:date.timezone ='Asia/Shanghai'(*重要*)不修改会导致PHP文件打不开

找到:expose_php = On

修改为:expose_php = OFF#禁止显示php版本的信息

找到:display_errors = On

修改为:display_errors = OFF#关闭错误提示

8、配置apache支持php

vi /usr/local/webserver/apache/conf/httpd.conf#编辑apache配置文件

LoadModule php5_modulemodules/libphp5.so这一行下面添加、

AddTypeapplication/x-httpd-php.php(注意:php .php这个点前面有一个空格)

/usr/local/webserver/apache/bin/apachectl-k restart#重启apache

service mysqldrestart#重启mysql

至此,CentOS 6.2编译安装Apache2.4.2+MySQL5.5.25+PHP5.3.13配置完成。

4rrdtool安装

yum install zib libpng freetype libjpeg fontconfiggd libxml2 cairo-devel libxml2-devel pango pango-devel

yum install libxml2-devellibpng-devel pkgconfig glib pixman pango pango-devel freetype freetype-develfontconfig cairo cairo-devel libart_lgpl libart_lgpl-devel

#./configure--prefix=/usr/local/rrdtool

可能会报下面这个错误
configure: error: Please fix the library issues listed above and try again.

还要确定是否安装了perlperl-devel如果没有安装在make的时候会报错。

解决方法yum -y installpango-develpango*perlperl-devel

#make &&make install

#ln -s/usr/local/rrdtool/bin/* /usr/local/bin/

5cacti安装

#mvcacti-0.8.8a/usr/local/webserver/apache/htdocs/

#mysql -uroot -pellisqin

mysql> createdatabase cacti;

Query OK, 1 rowaffected (0.03 sec)

mysql> grantall privileges on cacti.* to cactiuser@localhost \

-> identified by "ellisqin";

mysql> flushprivileges;

Query OK, 0 rowsaffected (0.02 sec)//重载MySQL授权表

#mysql-ucactiuser -pellisqin cacti <cacti.sql//导入cacti数据库

#viinclude/config.php

$database_default= "cacti";

$database_hostname= "127.0.0.1";

$database_username= "cactiuser";

$database_password= "ellisqin";

#crontab –e,加入如下内容,让cacti每五分钟采集一次数据

*/5 * * * * envLANG=C /usr/local/webserver/app/bin/php/usr/local/webserver/apache/htdocs/cacti/poller.php

#service crondstart

访问http://ip/cacti

问题1Warning: strtotime() [function.strtotime]:

解决方法

1:改 php.ini

date.timezone ='Asia/Shanghai'

2:在程序代码中写入

#vi include/global.php

<?php

date_default_timezone_set('Asia/Shanghai');//添加这一行

/*

问题2The following PHP extensions are missing: *sockets

原来是安装php时没有配置socket支持

哎,没办法只能重新编译下php,添加socket支持

1.不用停止 apache

2.进入 apache 的模块目录,备份一下php模块.

cd/usr/local/apache2/modules/

cp libphp5.solibphp5.so.bak

3.进入php的源码目录下,由于已经成功编译过,会有一个成功的config.nice文件,打开这个文件并重新配置,增加 socket 支持

cd/usr/local/src/php-5.2.4

viconfig.nice

增加一行

'--enable-sockets'

4.重新生成配置文件
shconfig.nice
5.
重新编译
make && make install
6.
重启 apache
/usr/local/apache2/bin/apachectl restart

----------------加载其他模块--------------

6、对Centos Linux机器进行监控采用两个版本

yum installnet-snmp net-snmp-devel net-snmp-utils

采用第一种版本V3

在笔者的试验环境下,CentOS下的net-snmp无法在selinux环境下正常使用v3。如果您想使用snmp v3,请先禁用selinux

net-snmp-config--create-snmpv3-user -ro -A hnjingpw -a MD5 qin

以上命令,创建一个snmpv3用户,只读,使用MD5,用户名为qin,密码为hnjingpw

注意:运行之前请先停用net-snmp服务。

我们可以使用snmpwalk来检测snmp服务是否正常开启。

shell>snmpwalk-v 3 -u qin -a MD5 -A "hnjingpw" -l authNoPriv 127.0.0.1 sysDescr

#shell>service snmpd start

采用第二种版本V2

编辑snmp配置文件/etc/snmp/snmp.conf

修改:com2secnotConfigUserdefaultpublic

改为:com2sec notConfigUser127.0.0.1(允许哪台机器捕捉数据)public

修改:accessnotConfigGroup ""anynoauthexactsystemview none none

改为:accessnotConfigGroup ""anynoauthexactall none none

去掉这句的注释#view allincluded .180

7Plugin Architecture安装 (不需要)

插件下载地址http://cactiusers.org/

#mysql-ucactiuser -pellisqin cacti<pa.sql

#cpcacti-plugin-0.8.7h-PA-v3.0.diff /usr/local/webserver/apache/htdocs/cacti/

#patch -p1 -N< cacti-plugin-0.8.7h-PA-v3.0.diff

#viinclude/global.php

$database_password= "ellisqin";

$url_path ="/cacti/";

$config['url_path']= $url_path;

8net-snmp安装

如果安装了net-snmpnet-snmp-devel net-snmp-utils就不需要安装第8步了

# yum -y installmysql-devel net-snmp-devel (*重要*) 不安装的话net-snmp完装不了

#./configure--prefix=/usr/local/net-snmp

#make &&make install

#cpEXAMPLE.conf/usr/local/net-snmp/share/snmp/snmpd.conf

#ln -s/usr/local/net-snmp/bin/* /usr/local/bin/

9cacti-spine安装

Cacti 在采集数据时使用的是cmd.php脚本,此脚本最短轮询时间为 5 分钟,也就说我们使用cmd.php 是无法将 cacti 轮询时间设置为每分钟轮询一次,因此,我们需要安装额外的高效轮询工具Spine

#./configure--prefix=/usr/local/cacti-spine--with-mysql=/usr/local/webserver/mysql--with-snmp=/usr/local/net-snmp(可不选,如果安装了net-snmp源码需要加上)

#make &&make install

#cd/usr/local/cacti-spine/etc/

#cpspine.conf.distspine.conf

#vispine.conf//配置连接 cacti数据库的信

报错:configure: error:Cannot find MySQL headers. Use --with-mysql= to specify

解决办法:# yum -y installmysql-devel

报错:configure: error:Cannot find SNMP headers

解决办法:# yum -y installnet-snmp-devel

#vispine.conf

DB_Host127.0.0.1

DB_Databasecacti

DB_Usercactiuser

DB_Passellisqin

cacti-spine报日志错误

cat/var/spool/mail/root

/usr/local/spine/bin/spine:error while loading shared libraries: libmysqlclient_r.so.18: cannot openshared object file: No such file or directory

做个软链接,问题解决

ln -s/usr/local/webserver/mysql/lib/libmysqlclient.so.18 /usr/lib64



本文转自Devin 51CTO博客,原文链接:http://blog.51cto.com/devingeng/1358376

相关文章
|
5月前
|
Linux 开发工具 C语言
Centos8下编译安装最新版ffmpeg解决方案(含Centos8换源阿里云)
Centos8下编译安装最新版ffmpeg解决方案(含Centos8换源阿里云)
824 3
|
12月前
|
Linux Python
[笔记]CentOS7中文乱码解决方案
[笔记]CentOS7中文乱码解决方案
230 0
|
12月前
|
监控 关系型数据库 MySQL
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
企业实战(8)CentOS 6.8安装Zabbix-agent 5.0监控主机性能与Mysql数据库
154 1
|
4月前
|
Linux 网络安全
杨老师课堂之关于阿里云Centos7 如何设置权限的解决方案
杨老师课堂之关于阿里云Centos7 如何设置权限的解决方案
55 0
|
1月前
|
运维 Linux
CentOS操作系统常见的故障处理
本文分享了CentOS操作系统网卡启动失败的故障处理方法,包括使用命令查看日志和禁用NetworkManager服务。
132 4
CentOS操作系统常见的故障处理
|
1天前
|
缓存 Linux 编译器
【C++】CentOS环境搭建-安装log4cplus日志组件包及报错解决方案
通过上述步骤,您应该能够在CentOS环境中成功安装并使用log4cplus日志组件。面对任何安装或使用过程中出现的问题,仔细检查错误信息,对照提供的解决方案进行调整,通常都能找到合适的解决之道。log4cplus的强大功能将为您的项目提供灵活、高效的日志管理方案,助力软件开发与维护。
8 0
|
5月前
|
网络协议 Linux
centos7部分桥接网络ping不通解决方案
centos7部分桥接网络ping不通解决方案
|
11月前
|
Linux
Centos8安装yum源时候出现的异常问题及解决方案(保好使)
Centos8安装yum源时候出现的异常问题及解决方案(保好使)
|
5月前
|
存储 监控 Linux
Flume【部署 02】Flume监控工具Ganglia的安装与配置(CentOS 7.5 在线安装系统监控工具Ganglia + 权限问题处理 + Flume接入监控配置 + 图例说明)
【2月更文挑战第17天】Flume【部署 02】Flume监控工具Ganglia的安装与配置(CentOS 7.5 在线安装系统监控工具Ganglia + 权限问题处理 + Flume接入监控配置 + 图例说明)
164 1
Flume【部署 02】Flume监控工具Ganglia的安装与配置(CentOS 7.5 在线安装系统监控工具Ganglia + 权限问题处理 + Flume接入监控配置 + 图例说明)
|
5月前
|
Linux 网络安全 Python
解决方案:Centos7运行Django项目报错no module named _ssl
解决方案:Centos7运行Django项目报错no module named _ssl
150 0