首页 > 学院 > 网络通信 > 正文

网络优化:使用cacti监测系统性能(图)

2019-11-04 20:33:26
字体:
来源:转载
供稿:网友

  前言:
  
  在论坛上经常看到有人问MRTG的问题,还有很多的关于MRTG的出色文章。MRTG的确是非常好用的,但我认为它究竟已经是一套很旧的软件了,其作者在多年前就已经开发了RRDTool代替该软件,现在已经发展得很成熟。既然有更好的选择,为什么我们还要用MRTG呢?
  
  第一部分,介绍:
  
  2004年我刚进某公司工作,当时我使用MRTG建立了一套系统,专门监测我们服务器和其它网络设备的流量。
  
  后来我想将其它的系统性能比如CPU负载、系统负载,网络连接数等一起监测起来。我在网上查找了很多的资料,也实现了这些功能,但总觉得实现的太费劲,治理起来太麻烦了。比如我有几百个被监测点,分布在不同的机房,而且我需要将这些服务器和网络设备分类,这样的话我就要将这些被监测点放在不同的mrtg配置文件中,运行多个crontab,而且自己还写了一些Html页面对其进行治理。
  
  后来有幸看到了一位师兄写的大作“rrdtool 教學”,里面列举了rrdtool的种种优点,于是我下定决心要将MRTG更换为rrdtool。
  
  MRTG的优点:简单、易上手,基本安装完了之后只要更改一下配置文件即可。
  
  缺点:1、使用文本式的数据库,数据不能重复使用;
  
  2、只能按日、周、月、年来查看数据;
  
  3、只能画两个DS(一条线、一个块);
  
  4、无治理功能;
  
  rrdtool的优点:
  
  1、使用rrd存储格式,数据能重复使用,比如我可以将一个rrd文件中的数据与另一个rrd文件中的数据相加。
  
  2、可以定义任意时间段画图,即你可以画出一张半年以来的数据的图,也可以画出一张半小时以来的图。
  
  3、能画任意个DS。
  
  4、CDEF让你能任意摆弄数据。
  
  缺点:
  
  1、rrdtool的作用只是存储数据和画图,它没有mrtg中集成的数据采集功能;
  
  2、在命令行的使用非常复杂,参数极多;
  
  3、无治理功能。
  
  简单的说,rrdtool就是一个强大的绘图的引擎。
  
  由于其非常复杂的命令,对用户非常不友好,我一度想自己用php写一套系统。幸运的是,半年前我找到了cacti(www.cacti.net)。对该工具我只有一个字形容:“great!”。
  
  cacti其实是一套php程序,它运用snmpget采集数据,使用rrdtool绘图。它的界面非常漂亮,能让你根本无需明白rrdtool的参数能轻易的绘出漂亮的图形。更难能可贵的是,它提供了强大的数据治理和用户治理功能,一张图是属于一个host的,每一个host又可以挂载到一个树状的结构上。
  
  用户的治理上,作为一个开源软件,它居然做到为指定一个用户能查看的“树”、host、甚至每一张图,还可以与LDAP结合进行用户的验证!我不由得佩服作者考虑的周到!Cacti还提供自己增加模板的功能,让你添加自己的snmp_query和script!可以说,cacti将rrdtool的所有“缺点”都补足了!
  
  最近在公司的内部培训中,我为Cacti画了两张图,里面是cacti的架构和cacti的工作流程,现在也一并发上来。
  
 网络优化:使用cacti监测系统性能(图)(图一)

  
 网络优化:使用cacti监测系统性能(图)(图二)

  第二部分:Cacti的安装
  
  该安装文档是我参照www.cacti.net上的官方文档进行安装后,总结出来的。平台是linux或FreeBSD。
  
  1、安装MySQL
  
  下载源码
  
  http://www.signal42.com/mirrors/mysql/Downloads/MySQL-4.0 /mysql-4.0.23.tar.gz
  
  for linux:
  
  http://www.signal42.com/mirrors/mysql/Downloads/MySQL-4.0 /mysql-standard-4.0.23-pc-linux-i686.tar.gz
  
  for freebsd47:
  
  http://www.signal42.com/mirrors/mysql/Downloads/MySQL-4.0
  
  /mysql-standard-4.0.22-unknown-freebsd4.7-i386.tar.gz
  
  安装
  
  代码:
  shell> groupadd mysql
  shell> useradd -g mysql mysql
  shell> cd /usr/local
  shell> gunzip < /PATH/TO/MYSQL-VERSION-OS.tar.gz
   tar xvf -
  shell> ln -s FULL-PATH-TO-MYSQL-VERSION-OS mysql
  shell> cd mysql
  shell> scripts/mysql_install_db --user=mysql
  shell> chown -R root .
  shell> chown -R mysql data
  shell> chgrp -R mysql .
  shell> bin/mysqld_safe --user=mysql &
  ./bin/mysqladmin -u root
  passWord "yourpasswd"
  
  基于安全的原因,为root用户设置密码才能让root用户登陆mysql,不然会有2002错误出现
  
  建立启动脚本
  
  代码:
  
  cp ./support-files/mysql.server
  /etc/init.d/mysql
  ln -s ../init.d/mysql S85mysql
  ln -s ../init.d/mysql K85mysql
  
  2、安装apache
  
  下载:
  
  http://apache.justdn.org/httpd/httpd-2.0.53.tar.bz2
  
  安装
  
  代码:
  
  ./configure --PRefix=/www --enable-so
  make && make install
  
  建立启动脚本
  
  代码:
  
  cp /www/bin/apachectl /etc/init.d/httpd
  cd /etc/rc3.d
  ln -s ../init.d/httpd S85httpd
  ln -s ../init.d/httpd K85httpd
  
  启动
  
  /www/bin/apachectl start
  
  3、安装php
  
  下载:
  
  http://us4.php.net/get/php-4.3.10.tar.gz/from/cn2.php.net/mirror
  
  安装:
  
  代码:
  
  /configure --prefix=/www/php
  --with-apxs2=/www/bin/apxs
  --with-config-file-path=/www/php
  --enable-sockets --with-mysql=/usr/local/mysql --with-zlib-dir=/usr/include
  --with-gd
  make && make install
  cp php.ini-dist /www/php/php.ini
  vi /www/conf/httpd.conf
  加入:
  AddType application/x-tar .tgz
  AddType application/x-httpd-php .php
  AddType image/x-icon .ico
  DirectoryIndex index.php index.html
  index.html.var
  ../bin/apachectl restart
  
  4、设置mysql
  
  代码:
  
  # mysql -u root -prootroot
  Welcome to the MySQL monitor.
  Commands end with ; or /g.
  Your MySQL connection id is 10
  to server version: 4.0.23-standard
  
  Type 'help;' or '/h' for help. Type
  '/c' to clear the buffer.
  
  mysql> create database cactidb;
  Query OK, 1 row affected (0.00 sec)
  
  mysql> grant all on cactidb.* to root;
  Query OK, 0 rows affected (0.01 sec)
  
  mysql> grant all on cactidb.* to
  root@localhost;
  Query OK, 0 rows affected (0.01 sec)
  
  mysql> grant all on cactidb.* to
  cactiuser;
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> grant all on cactidb.* to
  cactiuser@localhost;
  Query OK, 0 rows affected (0.01 sec)
  
  mysql> set password for
  cactiuser@localhost=password('cactipw');
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> exit
  
  5、安装rrdtool
  
  下载:http://people.ee.ethz.ch/~oetiker/weBTools/rrdtool/pub /rrdtool-1.0.x/rrdtool-1.0.50.tar.gz
  
  然后 ./configure
  make && make install
  
  即可
  
  与mrtg相比,rrdtool自带了gd库,所以不用先安装gd库。(不过由于rrdtool自带的gd库不支持中文,所以rrdtool画出来的图也不能有中文,否则会出现乱码)。
  
  注重:rrdtool1.2的版本由于已经不再自带外部的lib库(如cgilib,zlib等),所以需要从http://people.ee.ethz.ch/~oetiker/webtools/rrdtool/pub/libs/下载这些库来安装。建议还是使用1.0的版本,比较方便。
  
  6、安装net-snmp
  
  几乎所有的网络设备和操作系统默认都安装了snmp服务。Unix系统安装的都是net-snmp或UCd-snmp(其实两个都是同一组人写的)。假如没有安装snmp,可以到net-snmp.sourceforge.org上下载源码编译安装。
  
  我这里说的安装SNMP服务并不是要求安装SNMPD,其实是Cacti需要用到net-snmp中的两个命令――snmpwalk和snmpget进行数据的采集。我们可以直接在系统中运行snmpwalk和snmpget看是否有该命令,假如有则不用安装了。
  
  7、安装cacti
  
  下载:
  
  http://www.cacti.net/downloads/cacti-0.8.6c.tar.gz
  
  安装
  
  代码:
  
  cp cacti-0.8.6c.tar.gz /www/htdocs
  tar xzvf cacti-0.8.6c.tar.gz
  mv cacti-0.8.6c cacti
  cd cacti
  
  导入表
  
  代码:
  
  /usr/local/mysql/bin/mysql –u root
  –prootroot cactidb < cacti.sql
  chown –R cactiuser rra/ log/
  
  设置


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表