中间件-0技术概述
- 格式:ppt
- 大小:1.08 MB
- 文档页数:41
中间件技术的简介1.1两层结构与三层结构长期以来,我们一直使用着"客户端/服务器"的两层结构,这种两层的结构曾让无数人为之兴奋和惊叹,即客户端提供用户界面、处理业务逻辑,数据库服务器接受客户端SQL 语句并对数据库进行查询,更新等操作,然后操作结果返回给客户端,如图所示。
在一个比较简单的计算机应用系统中,采用两层体系结构的确给人们带来了相当的灵活性。
但随着计算机应用水平的飞速发展、企业信息化水平的不断深入、企业客户的不断增加,以及新业务的不断出现,越来越多的用户对计算机应用系统提出了更高的要求:1.要能够同时支持成千上万乃至更多用户的并发服务请求2.由单一的局域网向跨多个网络协议的广域网扩展3.不仅要支持一般的信息管理,而且还要支持关键业务的联机交易处理4.从支持单一的系统平台和数据源转向支持异构的多系统平台和多数据源面对用户的新需求,二层结构的应用模式由于采用客户机与服务器直接联接的方式形成了其固有的一些缺陷:1.难以维护client/server结构用户界面、业务逻辑和数据逻辑相互交错,通常在第一次部署的时候比较容易,但难于升级或改进,而且经常基于某种专有的协议(通常是某种数据库协议)。
它使得重用业务逻辑和界面逻辑变得非常困难。
2.难以扩展随着系统的升级,系统复杂程度大大增加,难以扩展,另外它是一个封闭的系统,很难与其他的应用系统实现互操作。
3.安全性差客户端程序可以直接访问数据库,可通过编程语言或数据库提供的工具直接对数据库进行操作,不安全4. 性能不好客户端直接与数据库建立连接,当有大量的并发用户存在时,会使数据库不堪重负,性能迅速下降,甚至当机。
三层结构为解决传统二层模式与应用需求日益突出的矛盾,以交易中间件为基础框架的三层应用模式应运而生,三层结构以中间层管理大量的客户端并为其联接、集成多种异构的服务器平台,通过有效的组织和管理,在极为宽广的范围内将客户机与服务器进行高效组合。
中间件技术概述李瑞轩华中科技大学计算机学院Overview of Middleware Technology 2006-3-7 2内容概要1. 分布式计算技术发展背景2. 中间件技术基础3. 中间件定义及特点4. 中间件的分类5. 中间件的发展趋势2006-3-7 31. 分布式计算技术发展背景M assivelyparallelprocessorM ultimediaO bject orientedO pen systemN etworks高速、低价和宽频带的数字通讯成熟的网络技术和面向对象技术发展迅速的先进微处理器采用微内核和多线程等技术的现代操作系统几乎完全无序的超大规模的异构网络互连环境M2O2N时代的来临2006-3-7 4分布对象技术应运而生新形式的软件危机升级的绞索开发的噩梦新一代的分布式计算技术分布对象技术=面向对象技术+网络通讯技术面向对象的多层客户/服务器软件开发的革命:产业化、标准化、集约化2006-3-7 5螺旋上升的发展道路分布对象技术传送对象传送请求——取得结果数据典型客户/服务器传送数据PC ——LAN的网络计算框架传送程序主机——终端的集中计算框架2006-3-7 6下一代分布式计算技术与Internet技术结合WWW从Hypertext Web、InteractiveWeb 到Semantic Web丰富的对象资源更有效的对象访问技术智能、主动的Agent技术向智能化、小型化和标准融合的方向发展2006-3-7 7实现分布式计算的技术路线80年代——理想的技术路线:试图在互连的计算机硬件上部署全新的分布式操作系统,全面管理系统中各自独立的计算机,呈现给用户单一的系统视图。
90年代——现实的技术路线:在网络计算平台上部署分布计算环境(也称为中间件),提供开发工具和公共服务,支持分布式应用,实现资源共享和协同工作。
当前人们所说的分布计算技术是指在网络计算平台上开发、部署、管理和维护以资源共享和协同工作为主要应用目标的分布式应用系统。
中间件定义及分类中间件(Middleware)是处于操作系统和应用程序之间的软件,也有人认为它应该属于操作系统中的一部分。
人们在使用中间件时,往往是一组中间件集成在一起,构成一个平台(包括开发平台和运行平台),但在这组中间件中必需要有一个通信中间件,即中间件=平台+通信,这个定义也限定了只有用于分布式系统中才能称为中间件,同时还可以把它与支撑软件和实用软件区分开来。
按照IDC的分类方法,中间件可分为六类。
1.终端仿真/屏幕转换:用以实现客户机图形用户接口与已有的字符接口方式的服务器应用程序之间的互操作;2.数据访问中间件:是为了建立数据应用资源互操作的模式,对异构环境下的数据库实现联接或文件系统实现联接的中间件;在分布式系统中,重要的数据都集中存放在数据服务器中,它们可以是关系型的、复合文档型、具有各种存放格式的多媒体型,或者是经过加密或压缩存放的,这类中间件将为在网络上虚拟缓冲存取、格式转换、解压等带来方便。
3.远程过程调用中间件:通过这种远程过程调用机制,程序员编写客户方的应用,需要时可以调用位于远端服务器上的过程;4.消息中间件:用来屏蔽掉各种平台及协议之间的特性,实现在不同平台之间通信,实现分布式系统中可靠的、高效的、实时的跨平台数据传输,实现应用程序之间的协同。
这是中间件中唯一不可缺少的,是销售额最大的中间件产品,主要产品有国内东方通科技公司的TongLINK、BEA公司的BEA eLink 、IBM公司的MQSeries等,目前在Windows 2000操作系统中已包含了其部分功能。
5.交易中间件:是在分布、异构环境下提供保证交易完整性和数据完整性的一种环境平台。
在分布式事务处理系统中要处理大量事务,常常在系统中要同时做上万笔事务。
在联机事务处理系统(OLTP)中,每笔事务常常要多台服务器上的程序顺序地协调完成,一旦中间发生某种故障时,不但要完成恢复工作,而且要自动切换系统,达到系统永不停机,实现高可靠性运行;同时要使大量事务在多台应用服务器能实时并发运行,并进行负载平衡地调度,实现昂贵的可靠性机和大型计算机系统同等的功能,为了实现这个目标,要求系统具有监视和调度整个系统的功能。
第1章中间件技术介绍中间件技术是现代计算机系统中常用的一种关键技术,用于支持各种应用程序之间的通信和交互。
中间件技术使得不同平台、不同语言、不同协议的应用程序能够无缝地进行数据传输和信息交换,提高了应用程序之间的互操作性和集成性。
中间件技术是在应用程序和操作系统之间的一个软件层,它位于底层操作系统和应用程序之间,用于屏蔽不同操作系统之间的差异和应用程序之间的复杂性。
中间件技术可以提供一系列的服务和功能,如消息传输、数据存储、分布式计算、事务管理等,以满足不同应用程序的需求。
中间件技术通常分为两类:基于消息传输的中间件和基于组件模型的中间件。
基于消息传输的中间件是一种通过消息传递来实现应用程序之间通信的技术。
它的基本原理是应用程序通过发送和接收消息进行交互,中间件负责将消息从发送方传递给接收方。
基于消息传输的中间件通常使用消息队列和发布/订阅模式来实现。
消息队列是一种存储消息的容器,发送方将消息发送到队列中,接收方从队列中获取消息并进行处理。
发布/订阅模式是一种将消息发布到主题或者订阅主题的订阅者进行接收的方式。
基于消息传输的中间件可以实现应用程序之间的解耦,提高系统的可伸缩性和可靠性。
基于组件模型的中间件是一种基于组件模型来实现应用程序之间通信的技术。
组件模型是一种将应用程序划分为独立的组件,并通过接口来定义组件之间的交互方式的模型。
基于组件模型的中间件通过提供组件容器、接口定义和消息传递等功能来实现应用程序之间的协作。
组件容器是一种运行时环境,用于加载和执行组件。
接口定义是一种描述组件提供的服务和属性的方式,用于组件之间的通信。
消息传递是一种通过消息来实现组件之间交互的方式。
基于组件模型的中间件可以实现组件的重用和组件之间的松耦合,提高系统的可维护性和可扩展性。
中间件技术在很多领域都有广泛的应用。
在企业应用开发中,中间件技术可以用于实现企业服务总线、分布式事务处理等功能。
在云计算和大数据领域,中间件技术可以用于实现分布式存储、分布式计算等功能。
一、概述1、中间件的概念随着计算机技术的飞速发展,各种各样的应用软件需要在各种平台之间进行移植,或者一个平台需要支持多种应用软件和管理多种应用系统,软、硬件平台和应用系统之间需要可靠和高效的数据传递或转换,使系统的协同性得以保证。
这些,都需要一种构筑于软、硬件平台之上,同时对更上层的应用软件提供支持的软件系统,而中间件正是在这个环境下应孕而生。
由于中间件技术正处于发展过程之中,因此目前尚不能对它进行精确的定义。
比较流行的定义是:中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源。
中间件位于客户机/ 服务器的操作系统之上,管理计算资源和网络通讯。
从中间件的定义可以看出,中间件是一类软件,而非一种软件;中间件不仅仅实现互连,还要实现应用之间的互操作;中间件是基于分布式处理的软件,定义中特别强调了其网络通讯功能。
2、中间件特点及优势通常意义下,中间件应具有以下的一些特点:满足大量应用的需要;运行于多种硬件和OS平台;支持分布式计算,提供跨网络、硬件和OS平台的透明性的应用或服务的交互功能;支持标准的协议;支持标准的接口。
程序员通过调用中间件提供的大量API,实现异构环境的通讯,从而屏蔽异构系统中复杂的操作系统和网络协议。
中间件提供客户机与服务器之间的连接服务,这些服务具有标准的程序接口和协议。
针对不同的操作系统和硬件平台,它们可以有符合接口和协议规范的多种实现。
由于标准接口对于可移植性和标准协议对于互操作性的重要性,中间件已成为许多标准化工作的主要部分。
对于应用软件开发,中间件远比操作系统和网络服务更为重要,中间件提供的程序接口定义了一个相对稳定的高层应用环境,不管底层的计算机硬件和系统软件怎样更新换代,只要将中间件升级更新,并保持中间件对外的接口定义不变,应用软件几乎不需任何修改,从而保护了企业在应用软件开发和维护中的重大投资。
中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源。
中间件技术原理与应用中间件是指位于客户端和服务器之间的一层软件,通过提供统一的接口和功能,实现不同系统之间的通信和互操作。
中间件技术在现代计算机系统中起到了至关重要的作用,它不仅提供了高效的数据传输和处理能力,还能够实现系统之间的解耦和灵活性。
中间件技术的原理可以简单概括为请求-响应模型。
当客户端发送请求时,中间件会接收并处理这些请求,然后将结果返回给客户端。
中间件可以根据具体的业务需求,对请求进行路由、转发、过滤和加工等操作,以保证数据的安全性和完整性。
同时,中间件还可以实现负载均衡和故障恢复等功能,提高系统的可用性和性能。
中间件技术在各种应用场景中都有广泛的应用。
在分布式系统中,中间件可以将不同节点之间的通信进行抽象和封装,简化系统架构和开发流程。
在消息队列系统中,中间件可以实现异步通信和解耦,提高系统的吞吐量和可扩展性。
在微服务架构中,中间件可以实现服务的注册与发现、服务的调用和容错处理等功能,提高系统的灵活性和可靠性。
以消息队列为例,中间件可以将消息发送方和接收方解耦,实现异步通信和削峰填谷。
消息发送方将消息发送到消息队列中,然后由消息接收方从消息队列中获取消息并进行处理。
这种方式可以降低系统的耦合度,提高系统的可靠性和性能。
同时,中间件还可以实现消息的持久化和重试机制,确保消息的可靠传输。
中间件技术还可以应用于分布式缓存系统中。
分布式缓存系统可以将数据缓存在中间件中,以提高数据的读取速度和系统的性能。
中间件可以实现数据的分片和复制,保证数据的可靠性和一致性。
同时,中间件还可以实现缓存的过期和更新策略,保证缓存数据的有效性和一致性。
中间件技术还可以应用于分布式事务处理中。
分布式事务处理是指在分布式环境下保证多个操作的一致性和原子性。
中间件可以实现分布式事务的协调和管理,确保事务的正确执行和回滚。
中间件可以通过两阶段提交协议和补偿事务等机制,实现分布式事务的一致性和可靠性。
中间件技术在现代计算机系统中具有重要的意义和作用。
中间件技术原理与应用中间件技术是指介于操作系统和应用软件之间的一种软件,它能够提供一系列的服务和功能,帮助应用软件更好地运行和管理。
中间件技术在计算机领域中有着广泛的应用,比如在分布式系统、数据库系统、消息队列系统等方面都扮演着重要的角色。
本文将从中间件技术的原理和应用两个方面来进行阐述。
中间件技术的原理主要包括以下几个方面,首先,中间件技术可以提供统一的接口和协议,使得不同的应用软件能够在不同的操作系统上运行,从而实现了跨平台的能力。
其次,中间件技术可以提供分布式系统的支持,帮助应用软件实现分布式计算和通信,提高了系统的可靠性和性能。
此外,中间件技术还可以提供事务管理和消息队列等功能,帮助应用软件实现数据的一致性和可靠性。
总的来说,中间件技术的原理是通过提供一系列的服务和功能,帮助应用软件更好地运行和管理。
中间件技术的应用主要体现在以下几个方面,首先,中间件技术在分布式系统中有着广泛的应用,比如分布式数据库系统、分布式文件系统等,它可以帮助应用软件实现跨网络的数据访问和共享。
其次,中间件技术在消息队列系统中也有着重要的应用,比如企业级的消息中间件系统,它可以帮助应用软件实现异步通信和解耦,提高了系统的可维护性和扩展性。
此外,中间件技术还在大型系统的集成和管理中有着重要的应用,比如企业应用集成(EAI)系统、企业服务总线(ESB)系统等,它可以帮助不同的应用软件实现集成和协同工作。
总的来说,中间件技术的应用涵盖了分布式系统、消息队列系统、集成系统等多个方面,它在现代计算机系统中有着广泛的应用。
综上所述,中间件技术是一种介于操作系统和应用软件之间的软件,它通过提供一系列的服务和功能,帮助应用软件更好地运行和管理。
中间件技术的原理主要包括统一的接口和协议、分布式系统的支持、事务管理和消息队列等功能。
中间件技术的应用主要体现在分布式系统、消息队列系统、集成系统等多个方面。
可以说,中间件技术在现代计算机系统中有着重要的地位和作用,它为计算机系统的发展和应用提供了强大的支持和保障。
中间件技术与开发指南近年来,随着互联网技术的飞速发展和应用场景的不断拓展,中间件技术越来越受到人们的关注和重视。
在构建大型复杂系统和平台时,中间件技术是不可或缺的一部分。
本文将从中间件技术的概念、特点、应用场景和开发指南等方面对中间件技术进行探讨。
一、中间件技术的概念与特点中间件技术,顾名思义,是处于软件系统之间的一种“软件”,主要用于连接、协调、转换、优化等功能。
它作为软件系统的一种基础设施,提供服务、管理资源和协调各系统之间的交互,对于保证系统的可靠性、可扩展性和灵活性具有重要作用。
中间件技术有多种类型,常见的有消息中间件、分布式缓存中间件、分布式事务中间件、分布式计算中间件、RPC中间件等。
不同类型的中间件技术在不同应用场景中发挥着各自的优势。
但所有中间件技术都具有如下特点:1. 抽象性:中间件技术屏蔽了底层的实现细节,对系统开发者提供了更高层次的抽象。
2. 可移植性:中间件技术通过标准化的接口和协议,提供了跨平台、跨语言的通信方式,从而保证了系统的可移植性。
3. 可靠性:中间件技术通常采用分布式架构,具有高可用、灾备和容错机制,保证了系统的可靠性。
4. 高性能:中间件技术采用了高效的通信和计算机制,具有较佳的性能表现,可以满足对高性能的需求。
二、中间件技术的应用场景中间件技术的应用场景非常广泛,涉及到各种复杂系统和平台的构建。
下面以几个典型的应用场景为例:1. 微服务架构微服务架构是一种较新的软件架构模式,其核心思想是将一个大型的系统拆分成多个小型的服务,每个服务独立运行、独立扩展,并通过中间件技术实现服务之间的通信和协作。
2. 高并发应用在高并发应用场景下,中间件技术可以通过分布式缓存、负载均衡、消息队列等方式实现系统的高性能、高可用和高可扩展性。
例如,分布式缓存中间件如Redis、Memcached等,可以提供高速的数据访问服务,大大缓解了数据库的压力。
3. 分布式系统传统的集中式系统难以满足大规模的系统需求,而分布式系统则是一种可以灵活扩展的系统结构。
中间件消息通信技术概要一、中间件中间件,就是介于应用系统与系统软件之间的一类软件,它使用系统软件所提供的基础功能,衔接于应用系统的不同部分,能够达到资源共享和功能共享的目的。
消息中间件,是中间件众多产品分类中一个重要部分。
它能够适用于任何需要进行网络通信的系统,负责建立网络通信的通道,进行数据或文件发送。
消息中间件的一个重要作用是可以实现跨平台操作,为不同操作系统上的应用软件集成提供服务。
二、几种通信技术的比较1、CPI-CCPI-C是一种同步对话通信模式。
参加通信的一方发起一次对话,同时控制信息流动。
数据既可以由发送者传递到接受者,也可以反向流动。
参加通信的两个程序需要跟踪对话的状态,如果异常发生导致连接中断,则需要发送方重建并恢复这次通话。
通信双方既可以处于主从地位,也可以处于对等地位。
也就是说,CPI-C既支持客户端-服务器环境,也支持对等通信方式。
虽然CPI-C在一般情况下是一种同步通信类型,但是在一定环境中,如CIC S,可以通过“临时数据队列”实现一定程度的异步。
TCP/IP,SNA都支持CPI-C。
由于需要应用程序参与错误的检测与恢复,CPI-C的编程接口相当复杂。
2、RPCRPC,即远程过程调用,也是一种同步,对话方式的类型。
一个调用程序向服务器提成申请,该调用被负责通信的转接器发往远端系统。
调用者与被调用者关系是固定的,很难实现对等通信。
与CPI-C一样,通信错误需要应用程序自己维护。
另外在申请服务得到响应之前,服务申请者被阻隔,这不仅是应用的瓶颈所在,更有可能遭受拒绝式服务攻击。
3、MQI(Message Queue Interface)消息队列接口为程序提供了一种异步通信方式。
一个程序以一个队列作为中转与另一个程序相互通信,这个队列向对于该程序而言既可以是本地,也可以是远程。
当程序A与程序B进行通信时,A只需要将消息放入一条与B相通信的队列即可,至于消息何时,以何种协议,何种方式到达程序B与A没有关系。
中间件技术1中间件的概念在众多关于中间件的定义中,比较普遍接受的是IDC表述:中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源;中间件位于客户机/服务器的操作系统之上,管理计算资源和网络通信。
IDC对中间件的定义表明,中间件是一类软件,而非一种软件;中间件是介于操作系统(包括底层通信协议)和各种分布式应用程序之间的一个软件层。
总的作用是建立分布式软件模块之间互操作的机制,屏蔽底层分布式环境的复杂性和异构性,为处于自己上层的应用软件提供运行与开发环境,帮助用户灵活、高效地开发和集成复杂的应用软件。
在具体实现上,中间件是一个用应用程序接口定义的分布式软件管理框架,具有强大的通信能力和良好的可扩展性。
中间件在分布式系统中的位置如图1所示。
2中间件的分类随着计算机软件技术的发展,中间件技术也已日渐成熟,并且出现了不同层次、不同类型的中间件产品。
按照IDC分类方法,中间件可分为以下6类:2.1终端仿真/屏幕转换用以实现客户机图形用户接口与已有的字符接口方式的服务器应用程序之间的互操作。
适用于应用程序与数据源之间的互操作模型,客户端使用面向数据库的API,以提请直接访问和更新基于服务器的数据源,数据源可以是关系型、非关系型和对象型。
这类中间件大都基于SQL语句,采用同步通讯方式。
此类中间件使应用开发简单化,但如果透过广域网使用,则会带来严重的效率问题,因为在低速网上来回交互SQL 语句会使通讯流量过大,同时对数据压缩、加密带来不便。
2.3远程过程调用中间件RPC机制是早期开发分布式应用时经常采用的一种同步式的请求应答协议。
通过这种协议,程序员编写客户方的应用,需要时可以调用位于远端服务器上的过程。
RPC扩展了过程语言中的“功能调用/结果返回”的机制,使得它可以适用于一个远程环境。
由于RPC 机制是同步方式,因而在工作的时候,要求客户方和服务方均能正确工作才能很好地运行,有一方不能工作将导致RPC失败。
中间件技术原理与应用初学者必看中间件技术是指位于客户端和服务器之间的一类软件技术,它可以提供一种可重用的、通用的、模块化的软件包,用于解决不同系统之间的通信和交互问题。
中间件技术的应用非常广泛,包括分布式系统、网络通信、消息传递等领域。
对于初学者来说,了解中间件技术的原理和应用是非常重要的。
1.远程过程调用(RPC):RPC是一种实现方法调用的技术,它允许程序在不同的计算机上通过网络进行通信,类似于本地函数调用。
通过RPC,可以实现分布式系统中不同节点之间的函数调用和数据传输。
2. 消息队列(Message Queue):消息队列是一种基于发布/订阅模式的通信机制,在消息队列中,消息的发送者将消息发布到队列中,而消息的接收者可以从队列中订阅并接收消息。
这种通信方式可以解耦消息的发送者和接收者,实现松耦合的系统设计。
3. 服务代理(Service Proxy):服务代理是一种通过代理服务器实现远程服务访问的技术,通过服务代理,客户端可以像访问本地服务一样访问远程服务。
服务代理可以屏蔽底层具体的实现细节,使得客户端和服务器之间的通信更加简洁和高效。
4. 连接池(Connection Pool):连接池是一种管理数据库连接的机制,通过连接池可以提高数据库的访问效率和并发性。
连接池可以预先创建一定数量的数据库连接,并将这些连接缓存在连接池中,当客户端需要访问数据库时,直接从连接池中获取连接,而不是每次都重新创建连接,从而减少了连接的创建和销毁的开销。
1.分布式系统:中间件技术可以帮助分布式系统实现节点之间的通信和协调,提供分布式系统的可靠性、扩展性和可管理性。
例如,分布式数据库系统、分布式缓存系统等都可以使用中间件技术来实现。
2.网络通信:中间件技术可以用于实现网络协议栈的各层功能,提供网络通信的基础设施。
例如,HTTP协议就是一种应用层的中间件,它提供了基于TCP/IP协议的高层抽象,使得应用程序可以简单地通过HTTP协议进行通信。
跟我学中间件相关技术及应用——与中间件技术相关的一些基本概念1.1.1与中间件技术相关的一些基本概念1、什么是中间件中间件是介于应用软件和操作系统之间的系统软件,但针对不同的操作系统和硬件平台,中间件可以有符合接口和协议规范的多种实现;因此,中间件是一种独立的系统软件或服务程序如IBM公司的WebSphere产品和BEA公司(现属于Oracle公司)的Weblogic 产品等。
IDC对中间件下的定义是“中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源,中间件位于客户机服务器的操作系统之上,管理计算资源和网络通信”。
分布式应用软件(如J2EE EJB组件)借助这种软件系统实现在不同的技术平台之间共享计算机中的各种系统资源,并由中间件系统软件统一管理各种系统资源和完成底层的网络通讯。
2、中间件技术产生的背景(1)传统的系统软件或工具软件提供的功能不能满足目前的企业应用的要求基于客户机/服务器(C/S)体系架构的企业应用系统已经流行多年,代之于Web技术、对象技术、数据仓库技术等新的概念和结构。
但随着对各种原有的应用系统不断进行功能扩充和新的应用系统不断地开发出,使得企业信息化应用也面临着许多问题——诸如不同硬件平台、不同网络环境、不同数据库之间的互操作等方面的问题。
因为多种不同系统平台、不同应用模式的系统相互并存,不仅系统效率过低、传输不可靠,而且数据加密和开发周期都比较长。
如何解决系统之间的“信息共享”和“平台互问”?(2)需要一种构筑于软、硬件平台之上同时对更上层的应用软件提供支持的软件系统为了能够使得各种应用软件在各种平台之间进行移植、同时也希望一种技术平台能够支持多种应用软件和管理多种不同的应用系统,软、硬件平台和应用系统之间也希望能够达到可靠和高效的数据传递或转换,最终使得系统的协同性(“信息共享”和“平台互问”)能够真正地得以保证。
为此,需要一种构筑于软、硬件系统平台之上,同时对更上层的应用软件提供支持的软件系统,而中间件正是为了满足这种应用环境而产生的。
一、构件技术与中间件构件技术的基本思想OO技术是在“"数据+算法”的基础上提升了对事物的认识方法,对象的概念符合人们认识世界的习惯。
而构件的思想则更多地将重点从建模本身发展到对软件生产的考虑,即构件可以在应用领域的软件生产中作为零件纳入新的体系中被重用。
因此,构件是OO思想的沿袭和扩展,认识事物的角度从对象个体本身上升到个体在群体中的作用。
构件有几个基本属性:1、构件是可独立配置的单元,因此构件必须自包容。
2、构件强调与环境和其他构件的分离,因此构件的实现是严格封装的,外界没机会或没必要知道构件内部的实现细节。
3、构件可以在适当的环境中被复合使用,因此构件需要提供清楚的接口规范,可以与环境交互。
4、构件不应当是持续的,即构件没有个体特有的属性,理解为构件不应当与自身副本区别,在任何环境中,最多仅有特定构件的一份副本。
可以看出,构件沿袭了对象的封装特性,但同时并不局限在一个对象,其内部可以封装一个或多个类、原型对象甚至过程,结构是灵活的。
构件突出了自包容和被包容的特性,这就是作为软件生产线上作为零件的必要特征。
构件技术的关键点涉及构件做什么、构件交互的规则、构件存在的环境等,相应在现实中有各种支撑性的技术,如:1、构件模型,研究构件的本质特征及构件间的关系;2、构件描述语言,以构件模型为基础,解决构件的精确描述、理解和组装问题;3、构件分类与检索,研究构件的分类策略、组织模式及检索策略,建立构件库系统,支持构件的有效管理;4、构件复合组装,包括源代码级的组装和基于构件对象互操作性的运行级组装;5、标准化,包括构件模型的标准化和构件库的标准化;6、软件构架,研究如何快速、可靠地应用可复用构件系统进行系统构造的方式,着重于软件系统自身的整体结构和构件间的互联。
中间件:构件存在的基础构件技术在最初时更多是作为一种思想存在,进而才在一些关键的环节上发展出解决问题的技术分支。
构件的存在某种程度上极大地依赖了构架技术,或环境、基础设施、计算平台,只有在适当的构架中,软件才有可能被抽象和隔离,最终成为构件。