电信网管中的java客户端(二)
1.概述
前文讲述了用java开发电信网管界面系统遇到的困难。其中,制作网络拓扑图是我们第一个必须克服的困难。本文概述如何使用和制作网络拓扑图的产品和方法和思路。
2.电信网络拓扑组件的要求
网络拓扑图是电信网管客户端的核心。对于电信网络,在使用任何网络拓扑组件时,必须注意电信网络的一些特点:
· 数据量大。一般电信网络的规模都比较大,网络设备数量多,拓扑复杂。网络拓扑图界面必须考虑到能够处理大数据量的网络节点和连接。
· 多层次展示网络。在一个综合电信网络中,各种类型设备往往相互连接、相互承载,运行在不同的网络协议层中。同时,电信设备在逻辑和物理上也可能分布在不同层次上。网络拓扑图必须有能力按层次的来组织各种网络资源。
· 高效率。网络拓扑图必须能高效、迅速的反应网管系统的数据变化。
· 轻量。拓扑图毕竟只是界面系统的一部分,它在开发、部署、运行资源占用上,都不应该太“重”。如果它是一个个头超过10兆、占用数十兆内存的模块,我认为很难接受。
· 简单易用。简单的就是好的。我们不想把开发人员的脑细胞都耗费在组件的使用上,而是网管系统的架构设计上。
3.可用产品
开源产品:最让人遗憾的是,目前还没有专门针对电信网管开发的开源的或者免费的java组件产品可以使用。虽然有jgraph等非常优秀的开源项目,但是如果用它来制作网络拓扑,还需要大量的开发和定制。希望将来能有开源或者免费产品的出现。
商用产品:其实选择也不多,罗列如下:
· ilog jtgo:这是该领域最著名的一个产品。你可以到google上搜索一下,看看有多少公司的招聘信息都提到这个产品。这是一个老牌电信界面组件产品,占据了绝大多数市场份额,产品功能非常全面、稳定。jtgo是基于ilog另外一个绘图产品jviews上开发的,所以它在开发和运行时都需要jviews包的支持,因此显得比较庞大(大约11兆)。jtgo提供了地图、设备面板图、树、表格等现成组件,以及大量文档和例程,为开发提供了很大方便。jtgo支持xml数据以及瘦客户端技术,非常适合在web上应用。但是,jtgo的架构设计比较复杂,api繁多,想要彻底精通这个产品的使用还是要费不少力气。
· jloox:jloox是一套功能很强大的java2d产品,有专门为电信行业提供而提供的jloox telecom产品包,专门用于电信行业oss/ems/nms界面开发。jloox在国内也有少量应用。不过,最近ilog已经正式从engenuity公司收购了jloox产品线。ilog在网站上声称,鼓励原有jloox客户转移到ilog的jviews产品上来,以获得更好的支持。由于jloox产品线和ilog既有产品线jviews/jtgo有太多的重合,这使得jloox的前景非常黯淡。
· serva software twaver:twaver是serva software公司的新产品。和上述产品具有完整的java2d绘图功能不同,twaver设计的目标非常明确,就是用于电信网管界面的开发。在功能上,它和jtgo有很大相似之处,包括提供的组件、业务对象、api设计、xml数据支持、编辑器程序等。twaver的最大优点是非常轻量、高效,易于使用。twaver的发布包不只有1兆左右,却可以承载数千个节点和连接,同时保持良好的响应速度,占用内存大约2.5兆/千节点。
4.使用架构
在电信网管界面的设计中,应该遵循mvc的设计原则,分离数据的存储、呈现和控制,便于系统进行扩展。
如果整个nms系统看成一个mvc框架,gui部分就算是系统的view了。在gui这个view内部,再按照mvc的原则,将各种界面呈现元素(对话框、组件包等)看作view,而各种资源、业务对象、运行信息等看作model。前后端的交互可以通过ejb调用、jms消息等方式完成。
由于各种网络拓扑组件产品的设计本身都遵循了mvc的设计原则,所以在设计整个gui架构时可以按照这种“mvc层层嵌套”的模式进行设计,以便系统的扩展。
5.结束
下次将使用ilog的jtgo以及serva的twaver用代码展示制作简单网络拓扑图的方法。