NMS开源软件选型分析评估报告

上传人:猪** 文档编号:63806058 上传时间:2022-03-20 格式:DOCX 页数:17 大小:339.86KB
收藏 版权申诉 举报 下载
NMS开源软件选型分析评估报告_第1页
第1页 / 共17页
NMS开源软件选型分析评估报告_第2页
第2页 / 共17页
NMS开源软件选型分析评估报告_第3页
第3页 / 共17页
资源描述:

《NMS开源软件选型分析评估报告》由会员分享,可在线阅读,更多相关《NMS开源软件选型分析评估报告(17页珍藏版)》请在装配图网上搜索。

1、NMS开源软件选型分析评估报告15目录1标准和目标11.1前言11.2目标11.3标准12评估22.1筛选22.1.1候选软件22.1.2License评估22.1.3软件功能评估32.1.4开发语言评估52.1.5小结62.2开发接口调查72.2.1Nagios72.2.2Opennms83结论144MISC141 标准和目标1.1 前言目前开源的网管软件众多,时间关系只能通过网络上的资料介绍和其他用户的体验进行评估。对于重点调查的开源软件通过运行环境搭建、开发环境搭建的方法进行实践。如果只是对通用网络设备的管理,被调研的软件只要经过适当的配置就可以满足要求。对于我们的需求,这些软件不能满足

2、我们100%的需求,必须进行二次开发,对软件二次研发的接口的调研就成为我们考察软件的一个重要的组成部分。部门对网管软件的定位应该不会投入过多的资金,商用软件价格高昂应该不在考虑范围之内,也尽量不选用开源软件商用版本,重点放在纯开源软件上。选择了一种开源软件也就选择了一种架构,所以架构的选择也要适合我们部门的开发能力。1.2 目标选择一款适合的开源软件,在此基础上进行整合和二次开发,构建部门设备网管平台。1.3 标准选型标准: License不仅仅是免费,无license限制是首选; 市场占有率广泛的市场占有率,说明软件得到过足够多的验证;针对于成功的开源软件,可以找到一些第三方的扩展资源,我们

3、只要遵循拿来主义就好; 功能一些功能可以直接拿来使用,或者简单的改造,可以节约成本; 完备的扩展开发接口被选择的开源软件是否已经提供完备的二次开发接口,满足二次开发的要求; 开发技术选择开源软件的另外一个层面考虑是尽量考虑使用部门成员最熟悉的开发技术,尽量避免涉及相对部门来说的新技术、开发语言,这样可以进一步研发降低成本; 开源架构就我们目前的需求,开源网管软件的功能,我们能用到的部分并不多。选择了开源其实主要就是选择它的架构。架构的开放性,易扩展性将直接决定我们的研发成本。2 评估开源网管软件的市场占有情况上图是网络监控软件的占有率。其中以Nagios和Opennms占有率最高。2.1 筛选

4、2.1.1 候选软件 Nagios Opennms Cacti Zenoss Zabbix SugarNMS2.1.2 License评估开源软件License使用限制NagiosGPLGPL(GNU General Public License)OpennmsFreeFree,也可以购买相应服务CactiGPLGPL ZenossGPLGPL2Zenoss提供开源版和企业版两种版本ZabbixGPLGPL2SugarNMS免费版、标准版、企业版免费开源和商业开源两个版本不是sourceforge下的产品2.1.3 软件功能评估The NRPE addon is designed to all

5、ow you to execute Nagios plugins on remote Linux/Unix machines开源软件功能Nagios网络服务监控(SMTP、POP3、HTTP、NNTP、ICMP、SNMP、FTP、SSH)主机资源监控(CPU load、disk usage、system logs),也包括Windows主机(使用NSClient+ plugin)可以指定自己编写的Plugin通过网络收集数据来监控任何情况(温度、警告)可以通过配置Nagios远程执行插件远程执行脚本远程监控支持SSH或SSL加通道方式进行监控简单的plugin设计允许用户很容易的开发自己需要的

6、检查服务,支持很多开发语言(shell scripts、C+、Perl、ruby、Python、PHP、C#等)包含很多图形化数据Plugins(Nagiosgraph、Nagiosgrapher、PNP4Nagios等)可并行服务检查能够定义网络主机的层次, 允许逐级检查, 就是从父主机开始向下检查当服务或主机出现问题时发出通告,可通过email, pager, sms 或任意用户自定义的plugin进行通知能够自定义事件处理机制重新激活出问题的服务或主机自动日志循环支持冗余监控包括Web界面可以查看当前网络状态,通知,问题历史,日志文件等 - 可以通过手机查看系统监控信息Opennms网络

7、节点自动发现图形用户管理界面故障监控故障事件管理操作系统监控网络节点配置信息管理全面的节点监控ZenossZenoss Core是开源企业级IT管理软件-是智能监控软件,他允许IT管理员依靠单一的WEB控制台来监控网络架构的状态和健康度。Zenoss Core同时也是开源的网络与系统管理软件。Zenoss Core的强大能力来自于深入的列表与配置管理数据库,以发现和管理公司IT环境的各类资产(包括服务器、网络、和其他结构设备)。Zenoss可以创建关键资产清单和对应的组件级别(接口、服务、进程,已安装的软件等)。建立好模型后,就可以监控与报告IT架构中各种资源的状态和性能容限了。Zenoss同

8、时提供与CMDB关联的事件和错误管理系统,以协助提高各类事件和提醒的管理效率。以此提高IT管理人员的效率。Zabbix- CPU负荷- 内存使用- 磁盘使用- 网络状况- 端口监视- 日志监视 SugarNMS1. 安全功能 支持多用户访问系统,每个用户可以管理不同的设备。系统记录用户操作日志和设备运行日志。2. 网络拓扑图 采用zhTelecom iTopoview技术,生动的展示网络结构图和拓扑图。对于大量的管理对象,可以通过划分组、网络、域 进行分级管理。大部分管理操作可以在拓扑图上直接进行。设备运行状况在拓扑图上可以直接显示。3. 故障管理 系统利用多种手段包括主动轮询、设备通报、性能

9、超标诊断等监控故障的发生,并能实时将故障通知到管理员。在拓扑图上通过不同颜色来提示不同级别的故障。可以查看故障的原因、发生时间、发生地等。支持故障智能分析,帮助管理员找到根本原因。4. 性能监控 系统可按预先定义的策略,定期的对被管设备进行性能监视,采集包括负载、容量、质量、连通性、错误率、工作状态、可靠度、服务状态等多种性能指标,提供实时和历史的性能数据报表。5. 性能分析 综合比较分析性能数据,发现网络瓶颈和潜在问题,为优化网络提供依据。预先对性能指标定义不同的警告阀值,在指标超过阀值的时候,提前通知管理员,能有效的预防故障发生。6. 设备配置管理 控制设备启动、恢复出厂设置,对设备固件升

10、级备份,配置各种运行参数、服务参数等。7. 管理工具集 在界面上集成各种外部管理工具,如Ping、Telnet、Web连接、各种专用工具等。8. 扩展支持 系统提供配置文件、数据库、程序 3个级别的修改扩展,实现对新功能的支持。2.1.4 开发语言评估开源软件语言其他细节NagiosCWeb php+cgiOpennmsJava,jsp/ Servlet,spring MVCMaven工程,支持eclipse开发CactiPHPZenossPythonZabbixC(backend) PHP(WEB)SugarNMSJavaJ2SE、XML、HTTP、JDBC、Swing、RMI、O-M Ma

11、pping、O-R Mapping等2.1.5 小结软件选项License(free得分2,GPL 得分1,商用得分0)市场占有率,以市场占有率高低依次计分功能(全面得分3,基本全面2,其他1)管理界面(FULL CONTRL2,其他1)开发语言(Java得分3,C/C+得分2,其他1)得分Nagios1631214Opennms2532316Cacti122218Zenoss1432111Zabbix1332211SugarNMS013239关于license,Opennms的license网站描述如下其他软件基本上都是在GPL限制下进行。如果我们选用了,在不付费的情况下就是涉及开放源码的问

12、题。但也可以打擦边球“一个关于GPL重要的争议是,非GPL软件是否可以动态链接到GPL库”。从市场占有率来讲,Nagios和opennms应用的比较广,也意味着更多的资料可以获取,更多的经验可以借鉴。从开发语言来说,Nagios使用c开发,界面PHP,cgi也是由c来开发的,由于c的复杂性,扩展开发上存在一定的难度,但是c对我们部门来说还是比较熟悉的。Opennms是基于java的,Web管理界面是基于JSP/ Servlet,Spring MVC。但是Nagios没有配置界面,配置需要直接修改配置文件。如果选用建议推翻所有目前的cgi方式的管理界面,全部重新开发,或者再结合其他的管理软件。C

13、acti基于PHP,zenoss基于python,zabbix基于c和php,SugarNMS开源程度不够,所以不做过多调研。从以上分析,倾向选择Nagios和opennms中的一种。调研过程中分别搭建了Nagios和Opennms的运行环境。搭建了Opennms的开发环境,(Nagios的编译环境,源码包解压缩就是开发环境,无所谓搭建了)。在搭建Opennms的过程中遇到一点点麻烦。Opennms的安装和编译环境搭建都比较费力,Opennms的编译环境依赖于Maven,eclipse的开发环境也需要花上一定的时间,尤其是公司的网络有诸多限制。Nagios编译和部署非常的顺畅,可以下载源码包直

14、接编译安装。2.2 开发接口调查基于上文中的调查,对于开发接口的调查只针对于Nagios和Opennms。2.2.1 NagiosNagios支持插件开发。支持C/C+,JAVA,脚本,并且有大量开发好的Plugins。插件是编译的可执行文件或脚本(Perl脚本,shell脚本等),可以从命令行运行检查状态或一个主机或服务。 Nagios的插件的使用结果来确定网络上的主机和服务的当前状态。Nagios在需要时执行Plugin检查服务或主机状态。NRPE方式:NRPE是一个插件,允许执行远程Linux/ Unix主机上的插件。如果需要监控远程主机上的资源和属性,如磁盘使用情况,CPU负载,内存使

15、用等,需要使用这种方式。通过使用check_by_ssh插件可以实现类似的功能。NSCA方式:NSCA是一个插件,允许你发送被动检查结果从远程Linux/ Unix主机到Nagios监控服务器上运行的守护进程。在分布式和冗余/故障监测设置,这是非常有用的。NDOUtils方式:NDOUtils是一个插件,允许把所有状态信息存储在MySQL数据库中的Nagios。 Nagios的多个实例都可以存储在一个集中的报告的中央数据库的信息。这可能会作为一个新的基于PHP的未来的Nagios的Web界面的基础上。Nagios提供了Nagios Plugin API。但是并没有提供除Nagios提供的功能外

16、的其他功能的开发。添加新的服务需要阅读c代码,难度上相对比较大。基于这一点,Nagios并不能满足我们的要求。2.2.2 OpennmsOpennms是装配式的,支持根据配置装载服务和插件,扩展性很强。上图为opennms的架构图,其中一些部分在最新版中有所变化。下表是opennms并发的进程并发任务守护程序名称英文描述操作守护程序actiondAction daemon - automated action (work flow)自动操作执行工具,用于根据入站事件自动操作(工作流)。采集守护程序collectdcollects data从受管节点采集数据。功能守护程序capsdcapabil

17、ity check on nodes对所发现的节点执行功能检查。它通常检查某个接口的端口,看它是否支持已知的服务协议。DHCP守护程序dhcpdDHCP client for OpenNMS为OpenNMS提供DHCP客户机功能。发现守护程序discoveryinitial and ongoing discovery互联网控制消息协议(Internet Control Message Protocol或简写ICMP)对受管网络节点进行初始的发现以及持续进行定期发现。事件管理器守护程序eventdmanages/stores events管理来自其它并发任务的事件,并将它们存储到RDBMS通知守

18、护程序notifdexternal notification of users向用户执行外部通知。故障管理器守护程序outagedOutage manager daemon - consolidates events合并事件,以为每个受管节点服务提供持续的历史故障视图。轮询器守护程序pollerdPoller daemon - polls managed nodes/services定期轮询受管节点服务,以决定操作状态。RTC管理器守护程序rtcdRTC manager daemon - real time availability information实时收集数据,为用户定义的各类受管节点

19、服务提供可用性信息。SNMP陷阱守护程序trapdSNMP trap daemon handles SNMP traps处理SNMP陷阱(事件)。阈值服务守护程序threshdThreshold daemon monitor for threshold values根据属性值是否达到指定的阈值来监控受管节点服务。支持总控/调度,发现,配置采集,性能采集,事件(告警)收集,轮询服务。通过在service-configuration.xml配置需要的服务。OpenNMS系统配置信息通过XML数据存储,基于linux系统和Postgres数据库的网络管理系统。网络数据通过JDBC对数据进行持久化,W

20、eb采用JSP/Servlet。OpenNMS是一个Open Source Framework,它采用了诸多的开源组件与框架,使用了各种协议的开源实现。每一个层面服务、功能都有自己的配置文件。OpenNMS采用了xml数据绑定技术(opennms采用的是castor)。根据xml文件的schema定义文件(xsd文件)生成对xml文件到java对象的映射,这样就不需要写解析xml文件的代码而是针对java对象进行操作。因此这些类都是在系统编译过程中由castor包根据xsd文件生成的。(Castor是一个Java开源数据绑定框架,它主要目标是提供Java对象与XML的绑定,Java到SQL的持

21、久化等.)Cleanimports是对java文件中的无用的imports作清理,并通过配置文件提供的格式对imports代码段进行格式整理。各种单元测试手段,HttpUnit,jWebUnit,Junit。nekohtml解析HTML,HtmlTidy对html字符串进行修正,并做标准化的处理。Avalon主要是一种Server的架构,可以满足配置、日志等服务器程序的需要。Jdhcp,java DHCP的实现。Xerces解析XML,API与实现有:xmlParserAPIs, xml-apis, xercesImpl。jCIFS,用Java开发的SMB客户端库。ldap-impl,LDAP

22、 java实现。smtp.jar pop3.jar,SMTP,POP3协议Java实现。JRobin基于LGPL授权的网络性能监控系统,是RRDTool的一个纯Java实现。joeSNMP,Java SNMP类库。WebUI:OpenNMS框架逻辑上采用了MVC架构,准确来说是JSP MVC Model 1,采用此架构的主要理念是尽量把逻辑与表示分离,这有利于系统健壮性,代码重用和结构清晰,便于重新设计,并长期维持。在OpenNMS中MVC各部分主要代表如下: 视图(JSP)OpenNMS的页面通过Model请求回来的内容以HTML,XML/XSL,图表等形式呈现给客户端。 控制器(Servl

23、et)OpenNMS的控制器采用Servlet方式的,配置在web.xml文件中,用来接受用户的输入并调用模型和视图去完成用户的需求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后用确定用哪个视图来显示模型处理返回的数据。 模型(Bussiness Object/Java Bean)模型表示企业数据和业务规则。模型允许重用相同的代码跨数个不同的用户界面组件。由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。开发接口:OpenNMS提供了一个简单快速的框架用来扩展设置缺省服务

24、与协议,为了扩展OpenNMS管理一个可定制的服务或协议需满足如下要求:以Caspd plugin为例 编写代码capsd plugin(插件)测试网络接口是否有支持期望的协议或服务 添加一个元素,在$OPENNMS_HOME的/etc/capsd-configuration.xml config定义新的服务。 编写代码poller插件,在某一特定的网络接口,监测当前期望的协议或服务的状态。 在$OPENNMS_HOME的/etc/capsd-configuration.xml config配置文件中添加和元素定义新的调用服务。1. 编写PluginCapsd使用plugin执行设备的性能检测

25、,一个Plugin是一个实现mgt.capsd.Plugin接口的Java类。下列接口中的方法必须实现:publicinterfacePluginpublicString getProtocolName();publicbooleanisProtocolSupported(InetAddress address);publicbooleanisProtocolSupported(InetAddress address, Map qualifiers);在配置文件capsd-configuration.xml添加,比如FtpPlugin 在运行时,性能daemon调用isProtocolSupp

26、orted()方法。此方法是每一加载的plugin通过它.InetAddress对象的每一个被发现的守护daemon,发现任何支持此接口的服务将通过接结点标识符与IP地址增加到ifservices数据表中。创建Poller PluginPoller daemon使用Poller Plugin轮询受管制接口所支持的服务当前状态。一个Poller Plugin是一个实现mgt.poller.monitors.ServiceMonitor接口的Java类。实现下面的poller plugin接口。publicvoidinitialize(java.util.Map parameters);publi

27、cvoidrelease();publicvoidinitialize(mgt.poller.NetworkInterface iface);publicvoidrelease(.NetworkInterface iface);publicintpoll(.NetworkInterface iface,mgt.utils.EventProxy eproxy,java.util.Map parameters);在poller-configuration.xml中添加一个新的服务,元素定义服务名称,多少时间间隔与预定时间,参数列表需定义在元素中。配置参数将通过poll()方法中的java.util

28、.Map传递给plugin在poller-configuration.xml文件中添加一个新的元素,在这个元素中说明服务名称与类名:每一种服务都有自身plugin的开发接口,方便扩展。2. 开发daemon开发plugin只能在现有服务的基础上进行扩展,但要增加基础服务,就必须开发daemon一级的服务。由于opennms是基于配置动态加载,我们可以模仿已有的daemon开发服务需要的服务进程。当然这需要相关代码比较熟悉。3 结论基于这段时间调研,感觉opennms比较适合我们的需要。Opennms前期需要投入一定的时间和人力进行调研,把相关层面的问题弄清楚。由于开始选型时设定了一个范围,会遗漏重要的软件,只盯在网管开源软件这个领域,也可能会错过其他一些更加符合我们的需要的开源架构软件。个人知识面的局限和偏执也会造成偏差。4 MISC如果部门决定选用opennms,那么下一步工作就是对opennms进行较为细致的实验。搭建实验环境。规划功能和制定开发计划。对开发接口进行实验。调研数据存储,数据库部分。然后就是功能裁剪。重新整合并发进程。逐步研发并添加一些需要的功能进来。对webUI部分进行改造,或者重新开发。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!