Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具。它通过snmpget来获取数据,使用 RRDtool绘画图形,而且你完全可以不需要了解RRDtool复杂的参数。它提供了非常强大的数据和用户管理功能,可以指定每一个用户能查看树状结构、host以及任何一张图,还可以与LDAP结合进行用户验证,同时也能自己增加模板,功能非常强大完善。
Cacti三层架构:数据展现层、数据存储层、数据采集层,其具体如下:
数据采集层:通过SNMP或自定义脚本进行数据采集
数据存储层:通过cacti模板等数据存放至MYSQL中
数据展现层:通过WEB方式呈现出来
Cacti应用场景
1)网络设备
(1)接口流量(进与出的带宽)
(2)监控CPU的负载、内存等等
(3)温度等等
2)主机系统
(1)网络接口流量(进与出的带宽)
(2)监控CPU的负载、内存等等
(3)监控磁盘的空间、进程数等等
3)cacti常见的监测对象
(1)服务器资源:CPU、内存、磁盘、进程、连接数等
(2)服务器类型:WEB、Mail、FTP、数据库、中间件
(3)网络接口:流量、转发速度、丢包率
(4)网络设备性能、配置文件(对比与备份)、路由数
(5)安全设备性能、连接数、***数
(6)设备运行状态:风扇、电源、温度
(7)机房运行环境:电流、电压、温湿度
nagios介绍
cacti 和 nagios 是不同功用的系统, nagios 适合监视大量服务器上面的大批服务是否正常, 重点并不在图形化的监控, 其集成的很多功能例如报警,都是 cacti 没有或者很弱的. cacti 主要用途还是用来收集历史数据和画图, 所以界面比 nagios 漂亮很多.
Nagios通常由一个主程序(Nagios)、一个插件程序(Nagios-plugins)和四个可选的附件(NRPE、NSCA、 NSClient++和NDOUtils)组成。
Nagios的监控工作都是通过插件实现的,因此,Nagios和Nagios-plugins是服务器端工作所必须的组件。
其它四个附件:
(1)NRPE:用来在监控的远程Linux/Unix主机上执行脚本插件以实现对这些主机资源的监控
(2)NSCA:用来让 被监控的远程Linux/Unix主机主动将监控信息发送给Nagios服务器(这在冗余监控模式中特别要用到)
(3)NSClient++:用来监控 Windows主机时安装在Windows主机上的组件
(4)NDOUtils:则用来将Nagios的配置信息和各event产生的数据存入数据库,以实现 这些数据的快速检索和处理
这四个ADDON(附件)中,
NRPE和NSClient++工作于客户端,
NDOUtils工作于服务器端,
而NSCA则需要同时安装在服务器端和客户端
nagios主要功能
网络服务监控(SMTP、POP3、HTTP、NNTP、ICMP、SNMP、FTP、SSH)
主机资源监控(CPU load、disk usage、system logs),也包括Windows主机(使用NSClient++ plugin)
可以指定自己编写的Plugin通过网络收集数据来监控任何情况(温度、警告……)
可以通过配置Nagios远程执行插件远程执行脚本
远程监控支持SSH或SSL加通道方式进行监控
简单的plugin设计允许用户很容易的开发自己需要的检查服务,支持很多开发语言(shell scripts、C++、Perl、ruby、Python、PHP、C#等)
包含很多图形化数据Plugins(Nagiosgraph、Nagiosgrapher、PNP4Nagios等)
可并行服务检查
能够定义网络主机的层次, 允许逐级检查, 就是从父主机开始向下检查
当服务或主机出现问题时发出通告,可通过email, pager, sms 或任意用户自定义的plugin进行通知
能够自定义事件处理机制重新激活出问题的服务或主机
自动日志循环
支持冗余监控
包括Web界面可以查看当前网络状态,通知,问题历史,日志文件等
3、结合实际应用选型软件
分析:
1)、 NRPE与SNMP协议
Cacti在LINUX下主要采用SNMP协议;snmp是简单网络管理协议,通过固定协议运行方式以OID格式提供系统运行状态的全面信息,然后通过snmp agent去获取这些信息并绘制流量。
NAGIOS在LINUX下主要采用NRPE插件,NRPE通过ssl方式在C/S结构下调用被监控主机的状态监测脚本,并将获得的信息实时提供到监控服务器。
2)、NAGIOS与CACTI区别
Cacti:在监控方面绘图比较不错,在流量与图型展现比较存在优势
Nagios:在故障分析比较不错,报警机制相对来说比较好,报警机制:邮箱、短信等,而且也比Cacti灵活;同时适用监控大量服务器以及服务器上面大批服务状态是否正常,重点不在图形化,而在状态故障的监控
综合所知:
cacti偏沉于收集流量画图,系统负载方面的。而nagios偏沉于系统状态正常与否方面的, nagios能够和短信发送机共同用来规模较大的网络,Cacti+Nagios 两者结合使用取长补短方为上上之策。
Cacti是一款使用PHP语言开打的性能与流量监测工具,监测的对象可以是linux或windows服务器,也可以是路由器,交换机等网络设备,主要基于SNMP(简单网络管理协议)搜集CPU占用,内存占用,运行进程数,磁盘空间,网卡流量等各种数据。
Cacti本身只是一个Web界面的管理软件,通过调用Net-SNMP工具来采集监测数据,并结合RRDtool(轮询数据库工具)记录数据并绘制图片。
注意:Cacti监测系统的搭建需要LAMP环境的支持,因此在搭建Cacti环境之前需要先将LAMP环境搭建好,还有本文的系统使用rhel6.0的系统,参考时注意自己系统的版本。
服务器端配置(主控端-Cacti)
1、构建支持Cacti的LAMP平台
在此使用系统光盘中的rpm格式的包,并使用yum进行安装,相关软件包如下。
[root@localhost/]#yum -y install httpd
[root@localhost/]#yum -y install mysql mysql-server mysql-connector*
[root@localhost/]#yum -y install php php-mysql php-pdo perl-DBD*unixODBC-*
上述分别是安装http mysql和php,也就是LAMP平台。
2、安装net-snmp-utils软件包
Cacti平台通过SNMP协议采集监测数据,因此需要用到snmpget,snmpwalk等SNMP数据采集工具,如下:使用yum一并安装。
[root@localhost/]#yum -y install net-snmp* lm_sensors
3、安装RRDtool软件包
[root@localhost/]# tar zxf rrdtool-1.4.5.tar.bz
[root@localhost/]# cd rrdtool-1.4.5
[[email protected]]#./configure--prefix=/usr/local
[[email protected]]# make&&make install
4、部署Cacti源码包
将下载好的Cacti源码包释放至Web服务器的网页目录。
[root@localhost/]# tar zxf cacti-0.8.7g.tar.bz
[root@localhost/]# mv cacti-0.8.7g/ /var/www/html/cacti
5、添加一个程序用户,用来读取检测的数据。
[root@localhost/]# useradd runct
[root@localhost/]# cd /var/www/html/cacti
[root@localhostcacti]# chown -R root:root./
[root@localhostcacti]# chown -R runct:runct rra/log/
6、建立数据库,并导入表。
先创建用于Cacti检测平台的数据库,并授权一个数据库用户,然后使用cacti源码目录下的cacti.sql脚本,导入预设的各种数据表。
如下图所示:
需要先启动mysqld服务,然后登陆mysq进行创建数据库操作。
[root@localhostcacti]# mysql-uroot -p
Mysql>create database cactidb default characterset utf8;
Mysql>grant all on cactidb.* to cactiuser@'localhost' identified by'123.qwe';
Mysql>exit
[root@localhostcacti]# mysql-u cactiuser -p cactidb 7、调整Cacti配置文件 Cacti的配置文件位于源码目录中的include/文件下,名为config.php。要使Cacti系统能够正确访问并使用数据库,必须修改config.php文件,确保数据库连接参数真确无误。修改如下: [root@localhostcacti]#vim /var/www/html/cacti/include/config.php $database_type="mysql"; $database_default="cactidb"; $database_hostname="lcoalhost"; $database_username="cactiuser"; $database_password="123.qwe"; $database_port="3306"; $database_ssl=false; $url_path="/"; 除此之外,为了在检测图像中正确显示中文,需要使用Cacti系统识别本机的中文语言环境。 需要修改“/lib/functions.php”文件。修改如下: [root@localhost/]#vim /var/www/html/cacti/lib/functions.php
Setlocale(LC_CTYPE,"zh_CN.UTF-8"); ......//省略部分内容 8、修改httpd服务的主配置文件,设置好网站根目录,自动索引页,默认字符集等相关参数,然后启动http服务。修改如下: [root@localhost/]#vim /etc/httpd/conf/httpd.conf DocumentRoot"/var/www/html/cacti" OptionsIndexesFollowSymLinks AllowOverrideNone Orderallow,deny Allowfromall DirectoryIndexindex.phpindex.html AddDefaultCharsetUTF-8 [root@localhost/]#service httpd start 9、初始化安装Cacti系统 在浏览器中访问Cacti服务器的Web服务,根据提示进行cacti初始化的安装操作。如下图所示:在浏览器中输入“http://cacti服务器的地址”根据提示选择“next”进行下一步安装,Cacti初始化安装时会检测安装环境,安装完成后,会出现Cacti登陆界面,默认用户名,密码都是“admin”,初次登陆会提示更改密码。 客户端配置(被控端-SNMPD) 无论是交换机,路由器,还是Linux系统或windows系统,只要正确支持SNMP协议,并允许Cacti服务器采集数据,就能够进行集中检测了。作者在此分别使用Linux系统和Windows系统来演示客户端的配置操作。 1、Linux客户端 在linux客户端,需要安装net-snmp、lm_sensors等软件包,并修改snmpd.conf配置文件,启动snmpd服务即可。 snmpd.conf配置文件修改如下: [root@localhost\]#vim /etc/snmp/snmpd.conf ......//省略部分内容 41com2secnot Configuser 192.168.1.1 Public 62accessnotConfigGroup""anynoauthexactallnonenone 85viewallincluded.1 2、windows客户端 windows客户端需要安装SNMP服务 安装完成以后,通过“服务器管理器”修改“SNMPService”服务的属性,指定授权地址(即cacti服务器的地址),共同体名等(即Public)。 使用Cacti检测客户端主机 1、添加被监控端主机 单击导航栏中“Management”下的“Devices”链接,可以管理被控制端设备或主机。通过右上角的“Add”链接,可以打开添加新设备的页面。 创建新的被监控设备以后,将自动连接目标执行SNMP查询,若查询成功则可以继续后面的检测项目设置,否则应检测被控端的SNMP设置,网络连接,防火墙限制,共同体名等相关因素以排除故障。成功连接被控端后会看到“SaveSucessful”的提示信息,页面下方可看到默认检测项目,管理员可根据需要检测的项目进行勾选。 2、生成检测图像 单击导航栏中“Create”下的“NewGraphs”链接,进入图像创建页面,选择指定被监控主机或设备,并选择其中最需要的图像条目。 单击导航栏中“Management”下的“GraphTrees”链接,在单击“DefaultTree”,可以对默认的图像检测树进行管理。我们可以单击右边的“Add”链接,将刚才创建的图像添加至检测树汇总。 3、定期采集检测数据 Cacti系统通过“poller.php”页面来采集检测数据,需要使用php程序解释执行。为了获得持续稳定的数据,应结合计划任务定期进行采集。 [root@localhost/]#su - runct//切换为数据采集账户 [runct@localhost/]# php /var/www/html/cacti/poller.php//手动执行数据采集 [runct@localhost/]# crontab -e //设置计划任务 */5****/usr/bin/php /var/www/html/cacti/poller.php&>/dev/null [runct@localhost/]#exit [root@localhost/]#service crond start [root@localhost/]#chkconfig crond on 4、查看检测结果 单击Cacti管理控制台左上方的“graphs”标签,然后展开左侧栏的“DefaultTree”树,选择被监控主机后即可看到个项检测图像。 添加Monitor、Thold插件 Cacti检测系统支持插件扩展,允许自定义图像模板和数据查询,从而能够灵活满足更加多样化的检测需求。下面通过安装及使用Monitor、Thold插件,介绍扩展Cacti检测系统功能的基本方法。 1、安装Monitor和Thold插件 将下载好的插件包解压到/var/www/html/cacti/plugins目录下即可。 [root@localhost/]#tar zxf monitor-0.8.2.tar.gz -C /var/www/html/cacti/plugins [root@localhost/]#tar zxf thold-0.4.3.tar.gz -C /var/www/html/cacti/plugins 2、调整cacti配置以识别插件 在cacti系统的web控制台中,单击导航栏中的“Utilites”下的“UserManagement”链接,修改admin用户的属性,选中“PluginManagement”项,单击“Save”保存即可。 刷新cacti控制台页面,左侧导航栏中“configuration”下将多出一个“PluginManagement”链接。单击此链接进入插件管理页面,通过“Actions”列的按钮可依次加载Monitor、Settings、Thold插件,并启用Thold插件。 使用状态监视插件——Monitor 单击导航栏中“configuration”下的“setings”链接,切换至“Misc”页面并选中“ShowlconLegend”以显示图例,将视图“View”设为“Tiles”。 若不希望某个设备被Monitor插件检测,则可以修改被监控主机属性,取消选中的“MonitorHost”即可。 使用阈值告警插件——Thold 1、设置接收告警邮件的邮箱地址 单击导航栏中的“ConfigUration”下的“Settings”链接,切换至“Thresholds”页面,选中“DeadHostNotifications”以便宕机或恢复时发送通知,同时应在“DeadhostsNotificationsEmail”外指定告警邮箱地址。 2、设置SMTP发信、DNS服务器等参数。 单击导航栏中的“ConfigUration”下的“Settings”链接,切换至“Mail/DNS”页面,将“MailServices”设为“SMTP”,并填写实际可用的发信地址,SMTP服务器,SMTP认证用户和密码,以及DNS服务器地址等信息。 3、设置需要报警的检测项目 单击导航栏中“Templates”下的“ThresholdTemplates”连接,切换至预警模板设置页面,单击“Add”可以添加预警项,数据模板应与被控设备使用的模板想匹配。 在设置各种检测模板时,告警阈值的默认计量单位如下:CPU使用率为百分比(不含%),网卡流量为Byte/S,硬盘空间为KB,内存占用为KB。 4、为被控主机启用阈值告警 单击导航栏中“Create”下的“NewGraphs”连接,选择指定的被控主机,然后单击右上方的“Auto-createthresholds”连接,将会自动创建可用的阈值告警项目。 5、查看,管理阈值警告。 单击导航栏中“Management”下的“Thresholds”连接,可以对以启用的阈值告警项进行管理(查看,添加,删除等);或者通过cacti管理页面上方的“Thold”选项卡,可以查看阈值告警情况,达到告警条件的检测项将以红色显示。 环境: 相关软件: Linux AS4 up4 mysql-5.0.22.tar.gz httpd-2.2.4.tar.gz php-5.2.4.tar.gz cgilib-0.5.tar.gz phpMyAdmin-2.11.1-all-languages.tar.gz rrdtool-1.2.11.tar.gz net-snmp-5.2.4.tar.gz cacti-0.8.6g.tar.gz 安装配置: mysql安装 解压缩:tar –zvxf mysql-5.0.22.tar.gz 改变目录:cd mysql-5.0.22.tar.gz 添加组:groupadd –g 20000 mysql 把用户加入组中:useradd –u 20000 –g mysql mysql 编译前的配置: ./configure –prefix=/usr/local/mysql --sysconfdir=/etc --localstatedir=/var/lib/mysql 编译:make 安装:make install 初始化数据库:/usr/local/mysql/bin/mysql_install_db 设置目录权限:Chown –R mysql /var/lib/mysql 复制配置文件:Cp /usr/local/mysql/share/mysql/my-medium.cnf /etc/my.cnf 启动数据库:/usr/local/mysql/bin/mysqld_safe –user=root & 修改root密码:/usr/local/mysql/bin /mysqladmin –u root password bobo365 测试数据库:/usr/local/mysql/bin/mysql –u root –p Mysql> 添加到自动启动: # cp support-files/mysql.server /etc/rc.d/init.d/mysqld # chkconfig --add mysqld #chkconfig –level 3 mysqld on 安装apache Tar –zvxf httpd-2.2.4.tar.gz Cd httpd-2.2.4 ./configure --prefix=/usr/local/apache --enable-so --enable-rewrite --with-included-apr (--enable-module=so --enable-module=most --enable-shared=max) Make Make install 安全加固: 隐藏和伪装apache版本:找到关键字ServerSignature将其设定为 ServerSignature off ServerTokens Pord 安装前编译ap_release.h文件,修改 “#define AP_SERVER_BASEPRODUCT\”Apache””为“#define AP_SERVER_BASEPRODUCT\”Microsoft-IIS/5.0\”” 编辑os/unix/os.h,修改“define PLATFORM\”Unix””为“define PLATFORM\”Win32”” 禁止显示动态目录索引: Options –Indexes FollowSymLinks 在rc.local上加入一行/usr/local/apache/bin/apachectl –k start,系统启动时启动Apache服务。 安装php (安装libxml,RedHat AS 4默认安装libxml包,但版本太低,PHP5需要更高版本的libxml包。 rpm -e libxml-devel rpm -e libxml http://xmlsoft.org/sources/old/ # tar –zxvf libxml2-2.6.25.tar.gz # cd libxml2-2.6.25 # ./configure # make # make install Tar –zvxf php-5.2.4.tar.gz Cd php-5.2.4 ./configure --prefix=/usr/local/php –with-mysql=/usr/local/mysql –with-apxs2=/usr/local/apache/bin/apxs --enable-sockets (# ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql --with-gd=/usr/local/libgd --enable-gd-native-ttf --with-ttf --enable-gd-jis-conv --with-freetype-dir=/usr/local/freetype –with-mail --with-jpeg-dir=/usr/local/libjpeg --with-png --with-zlib-dir=/usr/local/zlib --enable-xml --enable-mbstring --enable-sockets) (./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs --with-config-file-path=/usr/local/php --enable-sockets --with-mysql=/usr/local/mysql --with-zlib-dir=/usr/include --with-gd) Make Make install Cp php.ini-dist /usr/local/lib/php/php.ini 修改httpd.conf文件: AddType application/x-httpd-php .php AddType application/x-httpd-php –source .phps 测试: phpinfo(); ?> 4、设置mysql [root@Bleach php-4.3.10]# /usr/local/mysql/bin/mysql -u root -pmysql mysql> create database cactidb; mysql> grant all on cactidb.* to root; mysql> grant all on cactidb.* to root@localhost; mysql> grant all on cactidb.* to cactiuser; mysql> grant all on cactidb.* to cactiuser@localhost; mysql> set password for cactiuser@localhost=password('cactipw'); 注:以上语句输出 Query OK, 0 rows affected (0.01 sec) 表示成功 mysql> exit Mysql设置完毕 5、安装phpMyAdmin Tar –zvxf phpMyAdmin-2.11.1-all-languages.tar.gz Mv phpMyAdmin-2.11.1 /var/www/html/phpMyAdmin Vi config.inc.php $cfg['Servers'][$i]['user'] = 'root'; $cfg['Servers'][$i]['password'] = 'bobo365'; 设置数据库连接。 http://ip/phpMyAdmin测试。 6、安装rrdtool (1).安装cgilib tar -zxf cgilib-0.5.tar.gz cd cgilib-0.5 make CC=gcc CFLAGS="-O3 -fPIC –I." cp cgi.h /usr/include/ cp libcgi.a /usr/local/bin/ 1).安装cgilib tar -zxf cgilib-0.5.tar.gz cd cgilib-0.5 make CC=gcc CFLAGS="-O3 -fPIC -I." mkdir -p /usr/local/cgilib/include cp *.h /usr/local/cgilib/include mkdir -p /usr/local/cgilib/lib cp libcgi* /usr/local/cgilib/lib (2)安装libart_lgpl Rpm –ivh libart_lgpl-2.3.11-2.i386.rpm Rpm –ivh libart_lgpl-devel-2.3.11-2.i386.rpm (3)安装rrdtool tar -zxf rrdtool-1.2.11.tar.gz cd rrdtool-1.2.11 ./configure --prefix=/usr/local/rrdtool --disable-python --disable-tcl make make install ln –s /usr/local/rrdtool/bin5 * * * * /usr/local/php/bin/php /usr/local/apache/htdocs/cacti /poller.php > /dev/null 2>&1 保存退出:wq 全部设置完毕。 打开浏览器 http://ip/cacti 进入cacti的初始设置页面 第一次默认登陆账号:admin 密码 admin 登陆后在新改个密码就OK 需要说明的还有路径 [Copy to clipboard]CODE: snmpwalk Binary Path : /usr/bin/snmpwalk snmpget Binary Path: /usr/bin/snmpget RRDTool Binary Path: /usr/rrdtool-1.0.50/src/rrdtool PHP Binary Path: /www/php/bin/php Cacti Log File Path: /www/htdocs/cacti/log/cacti.log Cactid Poller File Path: /www/htdocs/cacti/poller.php 注:此时graphs还不能显示图形,需要将服务重新启动一下 [Copy to clipboard]CODE: [root@Bleach scripts]# service snmpd restart [root@Bleach scripts]# service mysql restart [root@Bleach scripts]# service httpd restart ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// 如果您是Linux主機的話請先確定你的snmpd.conf有無下面字串 view systemview included .1.3.6.1.2.1.2 如果沒有請自行加入 此字串是偵測Interfaces 請先確定您的Devices的Data Query有新增SNMP - Interface Statistics 到Create → New Graphs → 選擇您要偵測的Host 在Data Query [SNMP - Interface Statistics]裡面勾選您要偵測的網卡介面 選擇右下角的Select a graph type:In/Out Bits或者您想要的單位 好了之後點選右下方的create送出新增 再到Graph Trees把剛剛的Host或者Graphs新增進去即可查詢 cacti-0.8.7.tar.gz cacti-plugin-arch.tar.gz cacti-spine-0.8.7.tar.gz CACTI的安装涵盖了LAMP各个方面,实际环境中完全可以使用成型的CactiEZ中文版直接安装。 安装完CactiEZ中文版后,授权其他设备有MYSQL管理权限: [root@CactiEZ init.d]#service mysqld stop [root@CactiEZ init.d]# mysqld_safe --user=mysql --skip-grant-tables --skip-networking & [root@CactiEZ init.d]# mysql -u root mysql mysql> update mysql.user set password=password("bobo365") where user="root"; Query OK, 0 rows affected (0.00 sec) Rows matched: 3 Changed: 0 Warnings: 0 mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) mysql> quit Bye [root@CactiEZ init.d]# ./mysqld start Starting mysqld: [ OK ] [root@CactiEZ init.d]# mysql -uroot -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.1.47 Source distribution mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | cacti | | mysql | | test | +--------------------+ 4 rows in set (0.00 sec) mysql> mysql> GRANT ALL PRIVILEGES ON *.* TO [email protected] IDENTIFIED BY 'bobo365' WITH GRANT OPTION; Query OK, 0 rows affected (0.00 sec) mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) mysql> quit [root@CactiEZ init.d]# ./mysqld restart 120731 12:07:58 mysqld_safe mysqld from pid file /var/run/mysqld/mysqld.pid ended Stopping mysqld: [ OK ] Starting mysqld: [ OK ] [1]+ Done mysqld_safe --user=mysql --skip-grant-tables --skip-networking 放行80、3306端口 # iptables -I INPUT -p tcp --dport 80 -jACCEPT ; iptables -I INPUT -p tcp--dport 3306 -j ACCEPT ; #service iptables save 1安装cacti依赖的软件,安装过程全选Y #yum install httpd php php-process php-ldap php-mbstringphp-gd php-pdo php-snmp php-mysql lm_sensors net-snmp net-snmp-utilsnet-snmp-libs rrdtool rrdtool-devel perl-DBI perl-rrdtool perl-DBD-MySQL wqy-zenhei-fonts 2装好依赖软件之后,snmp有3个地方需要配置一下 3 #vim /etc/snmp/snmpd.conf 第41行:将 com2secnotConfigUser default public 中的 "default" 改为 "127.0.0.1" 提示 :41可直接跳到41行,下面同理 第62行: 将 accessnotConfigGroup "" any noauth exact systemview none none 中的 "systemview" 改为 "all" 第85行:将 #viewall include .1 80 这一行前面的 # 号去掉 4 配置好snmp以后我们来启动2个重要的服务 #s ervice snmpd start ; service httpdstart ; chkconfig snmpd on ; chkconfig httpd on 5安装并配置cacti #wget http://www.cacti.net/downloads/cacti-1.0.1.tar.gz #tar xzvf cacti-1.0.1.tar.gz #mv cacti-1.0.1 /var/www/html/cacti 6下载和设置mysql数据库 #wget https://dev.mysql.com/get/mysql57-community-release-el6-9.noarch.rpm //下载mysql的yum源,以安装mysql5.7,默认的版本和cacti不兼容 # rpm -ivh mysql57-community-release-el6-9.noarch.rpm # yum install mysql-community-server 7修改MySQL的配置文件(默认为/etc/my.cnf), 在[mysqld]下添加一行 skip-grant-tables #service mysqld start; chkconfig mysqld on #mysql mysql> update mysql.user setauthentication_string=password('新密码') where user='root' and Host ='localhost'; mysql> flush privileges; mysql> quit; 8将/etc/my.cnf文件还原,重新启动mysql #mysql -uroot -p //输入刚才设置的密码 mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '数据库密码'; //再次执行修改密码的命令(和之前的密码相同),新版数据库的安全要求高 mysql>create database cacti; //首先创建cacti数据库,注意别丢了分号 mysql>grant all privileges oncacti.* to cacti@localhost identified by '新密码' with grant option; //创建cacti用户并授权 mysql>use cacti; mysql>source /var/www/html/cacti/cacti.sql; //导入cacti数据库文件 mysql>grant select on mysql.time_zone_nameto 'cacti'@'localhost' identified by '数据库密码'; //给cacti 对mysql.time_zone_name表的查询权限(这两个命令需执行,否则安装中途会报错) mysql> flush privileges; mysql>exit 9 #vim /var/www/html/cacti/include/config.php $database_type = "mysql"; $database_default = "cacti"; $database_hostname ="localhost"; $database_username = "cacti"; $database_password = " 数据库密码 "; $database_port = "3306"; 执行命令,否则安装过程会报错 # mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -p mysql 10修改mysql默认参数,以支持cacti版本要求(直接粘贴到最后一行) #vim /etc/my.cnf log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid max_heap_table_size=400M max_allowed_packet=16777216 tmp_table_size=64M join_buffer_size=64M innodb_buffer_pool_size=1912M innodb_doublewrite=OFF innodb_flush_log_at_timeout=3 innodb_read_io_threads=32 innodb_write_io_threads=16 # service mysqld restart 11修改目录的所有者为apache # cd /var/www/html/ # chown -R apache:apache cacti 12:增加cacti 用户以用来写入rrd和log目录的数据,否则就会生成不了图片 #useradd cacti #cd cacti #chown -R cacti rra/ log/ 13:添加任务计划 具体多长时间让cacti生成一次监控图表自己决定,这里以cacti的默认时间5分钟生成一次为例 #crontab -e 加入这一行保存即可 */5 * * * * php /var/www/html/cacti/poller.php > /dev/null 2>&1 14在浏览器输入 http://ip/cacti 图片不太清晰,在倒数第三个图注意下,其它的默认下一步就行了 被监控服务器 需要查看网卡流量, 磁盘空间等信息。修改如下。 vi /etc/snmp/snmpd.conf 1、找到com2sec notConfigUser default public 改为:com2sec notConfigUser 192.168.1.1(改成监控服务器的ip) public 2、找到access notConfigGroup "" any noauth exact systemview none none 改 为:access notConfigGroup "" any noauth exact all none none 3、找到#view all included .1 80 将前面的 # 注释 去掉。 #以下为访问项目,如果想监控磁盘空间,load等需把注释去掉 #编译安装默认已去掉,自带安装的需手动把注释去掉 # Make sure mountd is running proc mountd #去掉前面的"#" # Make sure there are no more than 4 ntalkds running, but 0 is oktoo. proc ntalkd 4 # Make sure at least one sendmail, but less than or equal to 10 arerunning. proc sendmail 10 1 # Check the / partition and make sure it contains at least 10 megs. disk / 10000 # Check for loads: load 12 14 14