‘壹’ 什么是中间件 中间件起到了什么作用
1、中间件是一类连接软件组件和应用的计算机软件,它包括一组服务。以便于运行在一台或多台机器上的多个软件通过网络进行交互。该技术所提供的互操作性,推动了一致分布式体系架构的演进,该架构通常用于支持并简化那些复杂的分布式应用程序,它包括web服务器、事务监控器和消息队列软件。
2、中间件(middleware)是基础软件的一大类,属于可复用软件的范畴。顾名思义,中间件处于操作系统软件与用户的应用软件的中间。
3、中间件在操作系统、网络和数据库之上,应用软件的下层,总的作用是为处于自己上层的应用软件提供运行与开发的环境,帮助用户灵活、高效地开发和集成复杂的应用软件。在众多关于中间件的定义中,比较普遍被接受的是IDC表述的:中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源,中间件位于客户机服务器的操作系统之上,管理计算资源和网络通信。
‘贰’ 中间件是什么干嘛用的
中间件是一种独立的系统软件或服务程序,是连接两个独立应用程序或独立系统的软件,即使它们具有不同的接口,但通过中间件相互之间仍能交换信息。
中间件在操作系统、网络和数据库之上,应用软件的下层,总的作用是为处于自己上层的应用软件提供运行与开发的环境,帮助用户灵活、高效地开发和集成复杂的应用软件。
随着计算机技术的快速发展,更多的应用软件被要求在许多不同的网络协议、不同的硬件生产厂商以及不一样的网络平台和环境上运营。这导致了软件开发者需要需要开发多种应用程序来达到运营的目的。所以,中间件技术的产生,在极大程度上减轻了开发者的负担,使得网络的运行更有效率。
(2)中间件能给软件开发带来哪些帮助扩展阅读
中间件技术
1、远程过程调用
一个应用程序使用RPC来“远程”执行一个位于不同地址空间里的过程,并且从效果上看和执行本地调用相同。事实上,一个RPC应用分为两个部分:server和client。server提供一个或多个远程过程;client向server发出远程调用。
在RPC模型中,client和server只要具备了相应的RPC接口,并且具有RPC运行支持,就可以完成相应的互操作,而不必限制于特定的server。
2、面向消息的中间件
MOM指的是利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成。消息放入适当的队列时,目标程序甚至根本不需要正在运行;即使目标程序在运行,也不意味着要立即处理该消息。
对应用程序的结构没有约束:在复杂的应用场合中,通讯程序之间不仅可以是一对一的关系,还可以进行一对多和多对一方式,甚至是上述多种方式的组合。多种通讯方式的构造并没有增加应用程序的复杂性。
3、对象请求代理
可向上提供不同形式的通讯服务,包括同步、排队、订阅发布、广播等等,在这些基本的通讯平台之上,可构筑各种框架,为应用程序提供不同领域内的服务,如事务处理监控器、分布数据访问、对象事务管理器OTM等。
4、事务处理监控
事务处理监控最早出现在大型机上,为其提供支持大规模事务处理的可靠运行环境。随着分布计算技术的发展,分布应用系统对大规模的事务处理提出了需求,比如商业活动中大量的关键事务处理。
‘叁’ 中间件有何作用
(1)通信支持
中间件为其所支持的应用软件提供平台化的运行环境,该环境屏蔽底层通信之间的接口差异,实现互操作,所以通信支持是中间件一个最基本的功能。早期应用与分布式的中间件交互主要的通信方式为远程调用和消息两种方式。
通信模块中,远程调用通过网络进行通信,通过支持数据的转换和通信服务,从而屏蔽不同的操作系统和网络协议。远程调用是提供给予过程的服务访问,为上层系统只提供非常简单的编程接口或过程调用模型。消息提供异步交互的机制。
(2)应用支持
中间件的目的就是服务上层应用,提供应用层不同服务之间的互操作机制。它为上层应用开发提供统一的平台和运行环境,并封装不同操作系统提供API接口,向应用提供统一的标准接口,使应用的开发和运行与操作系统无关,实现其独立性。
中间件松耦合的结构,标准的封装服务和接口,有效的互操作机制,从而给应用结构化和开发方法提供有力的支持。
(3)公共服务
公共服务是对应用软件中共性功能或约束的提取。将这些共性的功能或者约束分类实现,并支持复用,作为公共服务,提供给应用程序使用。通过提供标准、统一的公共服务,可减少上层应用的开发工作量,缩短应用的开发时间,并有助于提供应用软件的质量。
(3)中间件能给软件开发带来哪些帮助扩展阅读:
中间件的特点:
1、应用支撑
中间件的最终目的是解决上层应用系统的问题,而且也是软件技术发展到今天对应用软件提供最完善彻底的解决方案。
现代面向服务的中间件在4个方面形成了很高地应用支撑能力,分别为软件的结构、模型、开发方法以及互操作,而要最终解决软件的灵活应变问题、效率问题、质量问题、互操作问题这四大问题,需要在软件技术的内在结构、架构层面进行思考。
2、耦合关系
中间件基于SOA架构,在松耦和解耦过程中演变成了境界。而传统软件将软件之中核心三部分数据转换、网络连接和业务逻辑所有的都耦合在一个整体,产生为铁板一块的软件,然后动一点而动全身,这样的软件就很难适应市场的需求。
而分布式对象技术可以分离连接逻辑,消息中间件异步处理连接逻辑,形成了很大的灵活性。中间件分离分布式对象与消息代理的数据转换。SOA架构以服务的封装,解耦实现了业务逻辑、数据转换与网络连接等。
3、互操作性
传统中间件在软件的互操作方面,通过标准化的API完成了同类系统之间的调用互操作,但是连接互操作离不开原有的特定的访问协议,比如CORBA用于的IIOP,JAVA用于的RMI等。
而SOA以支持Internet、标准化及操作系统无关的SOAP协议完成了连接互操作。并且服务的封装一般使用XML协议,它有自定义及自解析的特性,因此基于SOA的中间件能够完成语义互操作。
‘肆’ 中间件软件的介绍
中间件处于操作系统软件与用户的应用软件的中间,为上层的应用软件提供运行与开发的环境并帮助用户开发和集成应用软件。它不仅要实现互连,还要实现应用之间的互操作,其网络通信功能是其最突出的特点。中间件是一种应用于分布式系统的基础软件,位于应用与操作系统、数据库之间,主要用于解决分布式环境下数据传输、数据访问、应用调度、系统构建和系统集成、流程管理等问题,是分布式环境下支撑应用开发、运行和集成的平台。分布式系统的数据传输问题是中间件需解决的最基本问题,随着软件技术的发展,中间件的应用领域逐渐扩大到应用调度、分布式系统构建与集成、业务流程管理等方面。中间件产品开发的核心思想是抽取分布式系统对于数据传输、信息系统构建与集成等问题的共性要求,封装共性问题的解决方法,对外提供简单统一的接口,从而减少开发人员面对上述共性问题时的难度和重复性工作量,提高系统的开发效率。
‘伍’ 软件领域中,中间件是什么意思有什么用谢谢大家!!!
中间件是为了解决应用程序对网络过分依赖的问题采取了一种有效的方法,在客户机和服务器之间加一层软件。它是基础软件的一大类,属于可复用软件的范畴。顾名思义,中间件处于操作系统软件与用户的应用软件的中间。
在操作系统、网络和数据库之上,应用软件的下层,总的作用是为处于自己上层的应用软件提供运行与开发的环境,帮助用户灵活、高效地开发和集成复杂的应用软件。在众多关于中间件的定义中,比较普遍被接受的是IDC表述的:中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源,中间件位于客户机服务器的操作系统之上,管理计算资源和网络通信。
中间件是一类软件,而非一种软件;中间件不仅仅实现互连,还要实现应用之间的互操作;中间件是基于分布式处理的软件,最突出的特点是其网络通信功能。
‘陆’ 物联网中间件的作用是什么
物联网的中间件是一种软件产品,它有两种模式,一种是介于操作系统与应用软件之间,另一种是介于硬件和应用软件中间,发挥支撑和信息传递的作用。
中间件一种计算机软件。再看它的名字“中间”件,简单粗暴的彰显了它的位置——在中间。直白地说,中间件是一种软件产品,它有两种模式,一种是介于操作系统与应用软件之间,另一种是介于硬件和应用软件中间,发挥支撑和信息传递的作用。
第一种模式中,中间件能管理计算机资源和网络通讯,将操作系统与应用软件连接起来,实现信息传递和交互。另一种模式中,中间件将管理集成硬件设备,将硬件数据信息集成并上传给应用软件,实现沟通交互。两种模式中,中间件都可以向下集成处理,向上直接为系统软件提供数据等资源。
在实际应用中,中间件还是比较神秘滴,它专业性很强,技术门槛高,而且它不是大众能直接使用的软件产品,这就直接导致除了专业人士,大众能与中间件打交道的地方很少。
中间件的应用范围也非常广泛,不仅涉及网络应用的各个层面,涵盖从基础通讯、数据访问到应用集成等众多的环节,还有工业硬件集成上的应用。现在针对不同的应用需求涌现出多种各具特色的中间件产品,常用的有交易中间件、消息中间件、集成中间件等等。
Noah 物联网平台,属于第二种模式的中间件技术,向下连接工业物联网硬件,向上对接业务软件,提供标准数据接口,是系统集成的利器,能帮助企业智能设备管理、数据管理和运维分析,提高系统运行效率、降低集成成本。
‘柒’ 物联网中间件的作用是什么
作为物联网应用中的重要软件组成部分,中间件是连接相关硬件设备和业务应用的桥梁,其主要功能包括屏蔽异构、实现互操作、信息预处理等。(1)屏蔽异构。计算机软、硬件间的异构,包括硬件(CPU和指令集,硬件结构,驱动程序等等)、操作系统(操作系统API和开发环境)、数据库(各种存储和存取格式)等等。其原因在于市场竞争、技术升级、投资保障等因素。物联网的异构特性主要表现在:物联网底层的信息采集设备种类繁多,如传感器、RFID、QR、摄像机、GNSS等,这些信息采集装置及其网关具有不同的硬件结构、驱动程序、操作系统等;不同设备采集的数据格式不同,因此,中间件需要转换所有这些数据的格式,以使它们可以被应用系统直接处理。(2)实现互操作。通过物联网,同一信息采集设备收集到的信息可能会被用于多个应用系统,不同应用系统之间的数据还需要彼此共享和互通。然而,由于异构性的原因,不同的应用系统产生的数据结果都依赖于计算环境,导致无法在多种软件之间、不同平台之间进行移植或移植。另外,由于网络协议和通信机制的不同,这些系统之间还无法进行有效的集成。而通过中间件,可以建立一个统一的平台,实现各个应用系统与应用平台之间的互操作。(3)预处理数据。物联网感知层要采集大量的信息,如果这些信息直接传送到应用系统中,将会使应用系统难以处理这些信息,甚至有出现崩溃的危险。而这个应用系统所要获得的并非那些原始数据,而是对它们有意义的综合信息。因此,中间件平台需要对这些海量信息进行过滤,并将其融合为有意义的事件再传送到应用系统。
‘捌’ 什么是中间件
这其实是一个比较虚的概念。广义的中间件范围很广。起沟通作用的都可以认为是中间件。甚至ODBC这样的东西你也可以认为是中间件。
现在用的比较多的中间件应该是BEA公司的tuxedo和IBM公司的weblogic?(好象是这个东西),我接触过一点tuxedo。oracle、sun和ms好象也有类似产品,不过用的人很少。tuxedo是这个领域的领导者,不过IBM正在追赶并有可能超过,毕竟,IBM就是IBM。
tuxedo这东西我们用来做数据库和前台应用之间的中间件。
使用了中间件之后,以前直接连接的前台应用程序和数据库之前就多了个tuxedo,现在前台程序把请求发给tuxedo,tuxedo再把请求发给数据库,数据库处理结束之后把结果返回tuxedo,tuxedo再把结果送回给前台。这样一搞,表面看复杂了很多。不过带来一些好处,比如:
安全。tuxedo的服务是定制的,这就有点象是存贮过程,因为应用程序无法直接接到数据库而只能通过tuxedo,所以应用程序无法做tuxedo服务之外的事情。你把你的应用逻辑写在tuxedo中,你就可以保证你的数据是安全的。
性能。有些数据库性能不好,比如oracle一个连接就是好多M,连接数一多,机器内存就没了,有了tuxedo之后,tuxedo负责连接数据库,连接数比较少,tuxedo可以用排队的方式来处理这些数据库请求,这样提高了性能。中间件的高级应用好象还可以把数据库分布在不同的机器上,由tuxedo动态分配前、后台的请求和处理,把它们搞在不同的机器上,所以你用了中间件之后如果后台数据库处理来不及,可以加一台机器,前台请求太多(比如网站)可以加多前台机器。你可以灵活的调整性能。
方便移植。业务逻辑做到了中间件里之后,你更换后台数据库、改变前台的开发工具什么的移植工作较小,因为中间件的工作改动不大。
应用服务器做的人好象就更多了。而且应用服务器这东西和中间件类似(逻辑上)我觉得它应用也是中间件的一种,不过大家一般说中间件都是指的狭义的中间件,就是tuxedo这些。
中间件应用领域很广的。简直大一点的应用都可以用到中间件。国内也有一些开发商自己写中间件,不过好象是自己用,没形成市场。