Security基础(五):部署Cacti监控平台、构建Cacti监测系统

一、部署Cacti监控平台

目标:

本案例要求部署一台Cacti监控主机,并安装相关监控组件,为进一步执行具体的监控任务做准备:

  1. 安装net-snmp、net-snmp-utils
  2. 安装LAMP及相关依赖软件包
  3. 部署Cacti监控平台
  4. 初始化监控页面

方案:

使用1台RHEL7虚拟机,安装部署LAMP环境、Cacti及相关的snmp组件包,配置数据库并对Cacti监控平台进行初始化操作。

步骤:

步骤一:准备基础软件包

1)安装LAMP环境

Cacti监控需要通过Web页面展示出来,并且还需要使用MySQL来存储一些变量数据,因此需要先为Cacti准备基础LAMP环境。因为Cacti监控其他主机数据时使用的是snmp协议,所以还需要安装net-snmp和net-snmp-utils软件包。

[[email protected] ~]# yum -y install httpd php php-mysql php-ldap \
    >php-xml mysql mysql-server net-snmp net-snmp-utils  lm_sensors
    [[email protected] ~]# service httpd start;chkconfig httpd on        //启动httpd服务
    [[email protected] ~]# service mysqld start;chkconfig mysqld on        //启动mysqld服务
    [[email protected] ~]# mysqladmin -u root password ‘111‘            //设置数据库管理员密码

2)源码安装RRDTool

Cacti监控的数据存储和绘图功能主要依赖于该软件,如果没有该软件则Cacti无法存储监控数据并绘制出监控图像。

[[email protected] ~]# tar zxf rrdtool-1.4.5.tar.gz
    [[email protected] ~]# cd rrdtool-1.4.5
    [[email protected] rrdtool-1.4.5]# ./configure --prefix=/usr/local
    [[email protected] rrdtool-1.4.5]# make && make install

步骤二:部署Cacti套件

1)解压部署Cacti软件包

Cacti是由PHP开发的Web页面套件,PHP代码通过使用snmp协议来获得监控数据,并代用RRDTool存储数据和绘制监控图像,所以在安装完成基础LAMP环境后,首先需要做的就是将Cacti软件包解压放置在Web服务器的网页根路径下。

[[email protected] ~]# tar zxf cacti-0.8.7g.tar.gz
    [[email protected] ~]# mv cacti-0.8.7g/ /var/www/html/cacti
    [[email protected] ~]# cd /var/www/html/cacti
    [[email protected] cacti]# useradd cactiuser
    [[email protected] cacti]# chown -R root.root ./
    [[email protected] cacti]# chown -R cactiuser.cactiuser rra/  log/

2)创建数据库并初始化

Cacti需要使用MySQL来存储部分动态数据,这里还需要给Cacti创建一个数据库,并使用Cacti提前准备好的数据文件,对数据库进行初始化。

[[email protected] cacti]# mysql -u root -p
    Enter password:                                        //密码为前面初始化的密码
    mysql> CREATE DATABASE cactidb DEFAULT CHARACTER SET utf8;  //创建数据库
    mysql> GRANT all ON cactidb.* TO ‘cactiuser‘@‘localhost‘ IDENTIFIED BY ‘pwd123‘;    //创建账户并赋权
    mysql> QUIT
    [[email protected] cacti]# mysql -u cactiuser -p cactidb < cacti.sql  //初始化数据库

3)修改Cacti的PHP源码文件,指定数据库名称及相关账户信息。

[[email protected] ~]# cd /var/www/html/cacti
    [[email protected] cacti]# vim include/config.php
    <?php
    $database_default = "cactidb";                     //设置数据库名称
    $database_username = "cactiuser";                     //设置账户名称
    $database_password = "pwd123";                     //设置密码
    ……
    ?>
    [[email protected] cacti]# vi lib/functions.php
    <?php
    setlocale(LC_CTYPE,"zh_CN.UTF-8");                    //定义语言
    ……

4)调整http配置文件,重新定义根路径

httpd配置文件使用DocumentRoot "/var/www/html"语句来定义网站页面根路径,默认路径为/var/www/html/,这里需要修改为/var/www/html/cacti。

[[email protected] ~]# vim /etc/httpd/conf/httpd.conf
    .. ..
    DocumentRoot "/var/www/html/cacti"
    .. ..

5)访问Cacti监控页面,并进行初始化设置

第一次登录Cacti需要进行一些简单的初始化操作,主要是设置几个主要的依赖程序的存储位置。

二、构建Cacti监测系统

目标:

沿用练习一,为监控客户端主机安装net-snmp并设置监控权限,并通过调整Cacti服务端配置,实现以下目标:

  1. 主机192.168.1.200上搭建Cacti系统
  2. 监测网关、网站、邮件三台Linux服务器
  3. 监控被监控端的CPU负载、网络流量、磁盘空间
  4. 发邮件给[email protected]

方案:

准备4台Linux虚拟机,1台部署Cacti监控系统,3台作为服务器同时也是被监控的对象,拓扑结构如下图所示。

实验沿用练习一的成果,cacti监控平台已经部署完毕,目前需要给所有被监控节点安装net-snmp,并通过修改配置文件设置监控权限。

步骤:

步骤一:被监控主机设置

注意:由于所有被监控主机均允许cacti监控服务器从本机提取监控数据,因此所有被监控主机都需要做如下操作,下面以网关服务器为例。

1)安装net-snmp软件

Cacti监控其他主机是通过简单网络管理协议(SNMP)收集被监控端数据信息,因此被监控端服务器都需要安装net-snmp以及lm_sensors。lm_sensors软件可以帮助我们来监控硬件信息如CPU的工作电压等数据。

[[email protected] ~]# yum -y install net-snmp lm_sensors

2)修改snmp配置文件

SNMP配置文件主要包括四个部分内容需要修改,第一步映射通讯名称到安全用户名称,第二步将用户加入到组中,第三步为组赋予访问视图的权限,第四步定义all视图。主配置文件设置完成后重启服务即可通过客户端访问该服务器获得系统信息,SNMP使用的端口号为UDP 161端口以及TCP 199端口。

[[email protected] ~]# vim /etc/snmp/snmpd.conf
    ……
    com2sec notConfigUser  192.168.1.200    public    //社区名称映射为安全名称
    group   notConfigGroup v1           notConfigUser    //将账户加入组
    group   notConfigGroup v2c           notConfigUser
    access  notConfigGroup ""  any   noauth   exact  all none none  //赋予notConfigGroup组对all视图的访问权限
    view all    included  .1        80                //定义all视图及相关权限
    ……
    [[email protected] ~]# service snmpd start;chkconfig snmpd on

3)查看SNMP服务运行状态,设置防火墙

默认SNMP监听udp的161端口和tcp的199端口,通过netstat命令可以查看该端口的监听状态,设置防火墙规则允许这两个端口的入站数据。

[[email protected] ~]# netstat -anpu | grep "snmpd"
    udp       0      0  0.0.0.0:161      0.0.0.0:*        16452/snmpd
    [[email protected] ~]# iptables -I INPUT -p udp --dport 161 -j ACCEPT
    [[email protected] ~]# iptables -I INPUT -p tcp --dport 199 -j ACCEPT
    [[email protected] ~]# service iptables save

步骤二:设置Cacti监控服务器

注意:本练习案例要求将3台被监控端主机均加入到Cacti系统,这里以Web服务器为例添加监控对象并生成监控图像。其它监控节点做相关操作即可。

1)添加监控主机

登录Web控制台(http://192.168.1.200),默认的管理账号、密码为 admin,首次登录时要求强制重设密码。添加被监控端主机时需要设置目标地址,并正确选择主机模板、设置社区名称。

登录Web控制台后,进入Devices菜单后点击Add添加被监控主机,如图-2所示。此时系统会要求填写相关表单信息,需要填写的项目参数描述见表-1,填写完所需项目表单后点击右下角的Create即可创建新的设备主机,同时在下方会出现图形模版以及数据查询模版,管理员可以根据实际需要继续添加需要监控的参数对象,确定后点击Save保存所有设置,效果如下图所示。

2)创建监控图像

通过以上操作,设备主机以及需要监控的性能指标已经创建完成,下面需要通过New Graphs菜单为Web服务器创建图形。进入新建图形界面后在Host列表中选择上一步添加的设备主机,并在需要监控的性能模版后点选对勾,设置完成后选择Create为被监控设备添加图形,如下图所示。

3)创建监控图像树

Cacti监控系统最终通过树状列表来查看被监控主机性能图形,我们可以创建多棵图形树,在每棵图形树下可以插入多个设备主机的图形信息。Cacti初始状态有一个名为Default的图形树,本案例中我们将创建一棵新的图形树,并将被监控端主机的图形添加进来。通过点击Graph Trees菜单打开图形树的设置界面。选择Add可以添加新的图形树,如图-5所示,提示输入Name(图形树名称)后点击Create(创建),本案例设置名称为Web,此时在Graph Trees界面中会出现Default与Web两棵图形树。点击进入Web树中,选择Add按钮添加上一步操作中创建的图形,如下图所示。

4)监控服务器定期收集被监控端主机信息

Cacti监控服务器需要通过SNMP收集数据信息并最终生成图形窗口,在Cacti软件包中已经自带了这么一个用于收集数据的PHP脚本,默认Cacti系统需要每五分钟收集一次数据,管理员可以通过计划任务实现每五分钟执行该脚本,也可以手动执行该脚本立即同步数据。

5)查看监控页面效果

最后,通过Cacti平台的graphs选项卡进入图形窗口,该窗口将以树状显示,案例中我们创建了一棵名为Web的图形树,并在Web树下添加了3台被监控主机的图形,最终查看效果如图-7所示。

[[email protected] ~]# crontab -e
    */5 * * * * /usr/local/php5/bin/php /usr/local/apache2/htdocs/cacti/poller.php

步骤三:实现邮件报警机制

1)安装插件补丁

[[email protected] ~]# tar -xzf cacti-plugin-0.8.7g-PA-v2.9.tar.gz
    [[email protected] ~]# mv cacti-plugin-arch /var/www/html/cacti/
    [[email protected] ~]# cd /var/www/html/cacti
    [[email protected] cacti]# patch \
    > -p1 -N < cacti-plugin-arch/cacti-plugin-0.8.7g-PA-v2.9.diff  //打补丁
    [[email protected] cacti-plugin-arch]# pwd
    /var/www/html/cacti/cacti-plugin-arch
    [[email protected] cacti-plugin-arch]# mysql –u cactiuser –ppwd123 cactidb <pa.sql //插入数据库

2)修改配置文件,正确设置数据库信息

[[email protected] cacti]# vim /var/www/html/cacti/include/global.php
    $database_type = "mysql"
    $database_default = "cactidb"
    $database_hostname = "localhost"
    $database_username = "cactiuser"
    $database_password = "pwd123"
    $database_port = "3306"
    [[email protected] cacti]# vim /var/www/html/cacti/include/config.php
    $url_path = "/cacti/"

3)修改权限

默认admin账户并没有开启插件功能,需要点击"User Management"菜单,在刷新出来的页面中找到"admin"账户,如图-8所示。点击进入admin账户设置页面。在"Realm Permissions"选项卡下找到"Plugin Management"并点选对勾赋予账户插件管理权限,如下图所示。

4)安装邮件报警插件

插件即是PHP源代码文件,解压后复制到Cacti目录下即可。

[[email protected] ~]# tar -xzf thold-v0.4.9-3.tgz
    [[email protected] ~]# tar -xzf setting-v0.71-1.tgz
    [[email protected] ~]# tar –xzf monior-v1.3-1.tgz
    [[email protected] ~]# mv monitor settings thold /var/www/html/cacti/plugins

刷新Web控制台查看Plugin Management页面内容如下图所示。下一步还需要点击插件名称左边的图标(向下的箭头)进行安装。

5)启用Thold插件

首先需要定义报警邮件列表,点击"Notification Lists",在刷新出的页面中点击“Add"按钮,在弹出的页面中填写报警通知的邮件账户列表,如下图所示。

其次,还需要设置发送邮件的服务器,效果如下图所示。

6)使用Thold监控具体对象参数

监控web服务器的/boot空间,如果该分区的已用空间已达到80M以上,那么将发送邮件报警。

点击"Thresholds",在弹出的页面中选择"Add"按钮添加被监控主机及监控图像,具体报警参数设置如下图所示。

7)验证

在web服务上向/boot分区写入较大的文件,使得该分区已用空间超过80%,测试报警是否正确工作。

原文地址:https://www.cnblogs.com/baichuanhuihai/p/8414676.html

时间: 2024-08-13 05:44:59

Security基础(五):部署Cacti监控平台、构建Cacti监测系统的相关文章

部署Cacti监控平台

1 部署Cacti监控平台 1.1 问题 本案例要求部署一台Cacti监控主机,并安装相关监控组件,为进一步执行具体的监控任务做准备: 安装net-snmp.net-snmp-utils 安装LAMP及相关依赖软件包 部署Cacti监控平台 初始化监控页面 1.2 方案 使用1台RHEL6虚拟机,安装部署LAMP环境.Cacti及相关的snmp组件包,配置数据库并对Cacti监控平台进行初始化操作. 1.3 步骤 实现此案例需要按照如下步骤进行. 步骤一:准备基础软件包 1)安装LAMP环境 C

全新SaaS运维监控平台构建书

第一部分 引言 伴随的IT服务的发展,IT服务的概念也在发生着巨大的变化.IT运维服务已经由原来局限在用户自身环境下的IT服务,延伸到覆盖公用云.私有云.外包服务商等多纬度.全天候的SaaS运维模式, 从狭义理解,IT服务仅仅是为了解决信息系统出现的故障,在系统出现停顿的时候可以快速的恢复.而目前的IT服务已经包含了更多的内容,IT服务渗透在信息系统的整个生命周期之中.本文基于该理念,对IT服务系统的实现进行分析研究.文章基于网脊运维通SaaS(Software as aService)模式理念

Cacti监控平台搭建

作为一名Linux SA,日常最重要的就是保证网站正常稳定的运行,我们需要实时监控网站.服务器的运行状态,这时需要借助开源软件(cacti.nagios.zabbix等)监控来实现. Cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用rrdtool生成图表呈现给用户.因此,snmp和rrdtool是cacti的关键. Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成.snmp抓到数据不是存

Linux监控篇—Centos7.4下构建zabbix监测系统

Centos7.4-构建zabbix监测系统 目录第一部分 实验环境第二部分 配置服务器端第三部分 配置被控端(被监控服务器)第四部分 配置邮件报警功能第五部分 测试验证邮件报警 第一部分 实验环境 Linux服务端一台IP地址:192.168.80.10需要软件:php-bcmath-5.4.16-42.el7.x86_64php-mbstring-5.4.16-42.el7.x86_64注意:需要公网环境(可以上外网),网上下载最新版本的zabbix服务从微软客户端下载字体(楷体)到本机 L

05: Cacti监控服务 、 Cacti监控实战

搭建Cacti监控服务器 192.168.4.56查看监控信息和配置都是通过访问web页面完成的.配置信息存储在数据库服务器里. 一.部署Cacti监控服务运行环境 LAMP#rpm -q httpd mariadb-server php#yum -y install httpd mariadb-server php#rpm -q mariadb php-mysql#yum -y install mariadb php-mysql #systemctl start httpd ; systemc

Cacti 监控平台搭建(基于Centos6.7)

作为一名 Linux SA,日常最重要的就是保证网站正常稳定的运行,我们需要实时监控网站.服务器的运行状态,这时需要借助开源软件(cacti.nagios.zabbix 等)监控来实现.Cacti 是用 php 语言实现的一个软件,它的主要功能是用 snmp 服务获取数据,然后用 rrdtool 储存和更新数据,当用户需要查看数据的时候用 rrdtool 生成图表呈现给用户.因此,snmp 和 rrdtool 是 cacti 的关键.Snmp 关系着数据的收集,rrdtool 关系着数据存储和图

构建Cacti监测系统

案例1:部署Cacti监控平台 案例2:构建Cacti监测系统 1 案例1:部署Cacti监控平台1.1 问题 本案例要求部署一台Cacti监控主机,并安装相关监控组件,为进一步执行具体的监控任务做准备: 安装net-snmp.net-snmp-utils 安装LAMP及相关依赖软件包 部署Cacti监控平台 初始化监控页面 1.2 方案 使用1台RHEL7虚拟机,安装部署LAMP环境.Cacti及相关的snmp组件包,配置数据库并对Cacti监控平台进行初始化操作.1.3 步骤 实现此案例需要

通用财经数据传输与监控平台1.0(泛型,接口与基类,Sql,Ibatis,Awt,Swing)

导言 本系统通过访问url接口,实现财经数据的获取以及实时的更新到用户本地数据库的功能,并且配备了实时的数据传输的监控平台.通过本系统,用户可以的得到并保存所需的财经数据(超过200张表),并能实时的查看数据传输是否正常以及传输中的过程. 目录结构 一.相关技术总结 1.通用DAO.Service.Action的设计与实现:(VERY IMPORTMANT) 面向对象设计:接口.基类.继承:泛型 (如通用类BaseObject.接口BaseDao与实现类BaseDaoImp的设计) 2.树Tre

Linux监控平台介绍、zabbix监控介绍、安装zabbix、忘记Admin密码如何做

19.1 Linux监控平台介绍 cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要PHP环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图 open-falcon为小米公司开发,开源后受到诸多