中间件(middleware)是基础软件的一大类,属于可复用软件的范畴。顾名思义,中间件处于操作系统软件与用户的应用软件的中间。中间件在操作系统、网络和数据库之上,应用软件的下层,总的作用是为处于自己上层的应用软件提供运行与开发的环境,帮助用户灵活、高效地开发和集成复杂的应用软件。
在中间件产生以前,应用软件直接使用操作系统、网络协议和数据库等开发,这些都是计算机最底层的东西,越底层越复杂,开发者不得不面临许多很棘手的问题,如操作系统的多样性,繁杂的网络程序设计、管理,复杂多变的网络环境,数据分散处理带来的不一致性问题、性能和效率、安全,等等。这些与用户的业务没有直接关系,但又必须解决,耗费了大量有限的时间和精力。于是,有人提出能不能将应用软件所要面临的共性问题进行提炼、抽象,在操作系统之上再形成一个可复用的部分,供成千上万的应用软件重复使用。这一技术思想最终构成了中间件这类的软件。
目前来看,对于中间件的应用需求,还主要集中在行业市场上,与前几年仅仅局限在金融、电信、政府等几个领域的市场状况不同,安防行业市场对于中间件的需求也逐步开始了,并有望占据比较大的市场份额。但是在应用层次上,还是有比较大的区别。
对于与安陆有关的行业而言,开始时依赖现有的套装产品,采购进来之后,直接进行应用。但是很快在应用过程中就会有更多的定制需求提出来。因为涉及的具体行业特征的不同,就会导致不问的应用需求。这就要求产品能够根据行业性的特征进行定制,去除不必要的功能和特性。目前,用户已经意识到了,市场上提供的套装产品,其70%的功能行业永远用不到的,所用到的功能不过只有30%。其中的原因,就在于产品就如同操作系统一样,拥有应用非常广泛的市场,需要满足很多不同的应用需求,因此导致功能比较庞大。是否能迅速做到根据不同的应用需求提供服务,中间件的引入就显得格外重要了。如今用户也很聪明,要求产品能够根据需求进行定制,而不是一个大而全,价格很高的东西。
因此,随着各行业市场安防监控业务的发展,成熟的产品还会有很大的市场空间,但与此同时,定制化的需求也对于中间件产品提出了更迫切的要求;需要安防企业在软件系统架构方面尽快转型。
中间件技术是安防技术发展必由之路
功能再复杂的产品都是由大量标准的零件(尽管零件可能只在本领域内有用)组成,零件在生产线上装配成一个成品,所有零件在成品中共同发挥作用。分工越细致、专业生产的程度越高,总体生产效率就越高。而中间件技术所扮演的角色就是把零件、生产线和装配运行的概念运用在在软件工业中,可以预见,中间件技术是软件产业化革命的必然发展趋势。从应用软件的角度来看,我们需要一个稳定的、技术依赖性较弱的方法来描述行业应用的不断升级的业务逻辑结构。业务逻辑会按照行业需求的不断深挖而发展,却不应该太多的因为技术的变化而重新编写。中间件思想的应用就可以很好的解决这一难题。
安防监控中间件就是为不断发展变化的、具有个性化特征的各个行业应用软件而打造的一个中间件平台。在为行业提供解决方案的时候,可以通过中间件迅速构建业务逻辑、部署应用并极其方便的与其他业务系统进行整合。
中间件解决了行业应用的结构问题。目前行业应用的选择有两个,即购套装软件和定制开发。一方面,套装软件的可塑性相对较差。如果用户有一些独特的需求就难以实现,而从零开发的应用软件固然能满足某时间点的固化需求,但是开发周期却过长,而且难于保证最终系统的质量,以及系统后期的需求变化和维护问题。通过面向中间件的开发,系统是按照个性化的需求,从一个比较完备、比较成熟的构件库组装而成,大大提高了系统的成功率、稳定性、适应性、逐步发展性。静观时下火爆的家庭装潢行业的构件化作业可见一斑。面向中间件的开发方式解决了行业应用的开发和管理问题。通过建立一个不断完整的构件库;行业的知识可以得到有效的管理。业务知识不是在上百万行的代码之中,也不是在每天晚上回家的员工脑里,而是在一个可见的,可控的构件库中,便于管理、衡量,达到持续发展的目的。开发人员可以看到自己的业务、知识和流程,也通过构件库来不断发展自己的核心竞争力。否则,有数百人的安防大企业和一个新开始的二、三十人的小公司有什么本质区别呢?很多软件工程师也面临这样一个问题。刚从学校出来的几年,大家比较喜欢技术钻研,熬夜写代码,找BUg。而后自己想想,收获在哪里呢?确实每个人都积累了很多经历和经验,但只是一个更熟练的代码工具。逐渐地大家希望自己能从日常的代码中逃离出来,去设计、规划一个大型的软件系统,而且能够长期持续发展。面向中间件的开发模式也正是这样的一个承载思想,承载知识,承载经验的平台。面向中间件是安防企业发展的希望,是优秀的软件架构师的希望。
安防中间件分类与突破
安防中间件可以划分为基础中间件、应用中间件和领域应用框架三类。其中,应用中间件主要有数据资源集成、应用资源集成、业务流程集成、门户集成等中间件。应用代码集成中间件和业务流程集成中间件都是针对信息系统业务层构建的。前者利用适配机制把各种新建和遗留应用代码中的各类方法统一成标准的应用接口,并包装为消息的形式,进而通过消息代理机制,实现应用资源之间跨网络的互连、互通和互操作。后者是对业务流程的整个生命周期进行管理和控制,协调参与流程的各应用资源代码之间的动态执行关系,并监控和分析其执行状况。业务流程集成中间件通常都提供可视化的开发方法。
与传统安防的软件开发方式相比,基于中间件的软件开发方法有什么突破呢?