背景环境:
超过100台服务器,根据功能划分有WEB、DB、WEB&DB类型的数据库组群。所有服务器都是Windows系列操作系统,都在一个统一的活动目录AD中,根据功能不同处于不同的OU中。
解决方案一:
在所有服务器上安装SNMP服务,设置信任IP地址。配置一台空闲机器做监控服务器,安装MRTG,收集所有需要监控服务器的性能数据,并在MRTG上用曲线图的方式显示出来。
优点:方案实施简单,没有什么技术难点,监控环节少。
缺点:需要在被监控服务器上安装SNMP。而我恰好有安装的服务能少就少的爱好。
解决方案二(目前实施的方案):
用WMI编写VBS脚本,利用ADSI读取活动目录AD中的服务器列表清单,并遍历这个清单,获得服务器的性能数据,并写入到监控服务器的数据库中(MySQL/SQL Server均可)。在监控服务器上安装 .Net Frame work、Visual Studio .Net 2003、Microsoft SQL Server 2000、SQL Reporting Services。利用Reporting Services生成性能数据图表。
服务器CPU占用率曲线图
优点:不需要在被监控服务器上实施安装。数据采集、输出报表可以自己定制。
缺点:需要自己动手写数据采集代码,监控环节复杂,需要在中央监控服务器安装众多庞大的微软产品,需要自己手动编写数据库查询语句来输出报表。
解决方案三:
使用MS的服务器监管软件MOM。