中间件学习——J2EE中间件四步曲

前面的几篇文章我们已经介绍了中间件的相关知识了,这篇我们文章我们了解下J2EE中间件。关于J2EE上一篇我们我们进行过初步的介绍,了解到J2EE它是一个规范与标准,这篇文章要介绍的内容有J2EE中间件技术、J2EE应用服务器中间件的体系结构和J2EE技术与.NET技术的比较。

J2EE中间件技术

J2EE体系

J2EE这个规范是应用服务器采用的主要技术体系,与其它的中间件系统相比较,它具有非常显著的特征,而特征来自它独特的体系结构。

比如企业现在需要通过他们为他们的客户、合作伙伴、雇员和供应商提供更加便捷的服务来扩大它们的市场、降低它们的成本及缩短它们的响应时间。这这种情况下,应用程序必须将现有的企业信息系统与可以为更多的客户提供服务的新业务功能结合起来,这些服务需要:

高可用性,可以适应当今全球商业环境;

安全性,可以保护客户的隐私和企业数据的完整性;

可靠性和伸缩性,保证实物处理的准确性和及时性。

由于多种原因,这些服务功能需要构筑成有多个层次组成的分布式系统,包括前端的客户端、后端的数据资源端和一个或多个中间层,这个中间层也是开发工作的重点,它实现了新的服务功能和数据与现有业务管理系统的结合。这个中间层将客户层分离出复杂的企业系统,采用先进的Internet技术,以减少对客户的管理和培训。

Java2平台企业版(J2EE)降低了开发这些服务功能的成本和复杂性,使服务可以迅速部署,以增强企业回应竞争压力的能力。J2EE通过以下一些元素定义出一个标准:

◆ J2EE平台一个用于搭建J2EE的多个应用的平台,定义了一组必要的API和策略;

◆ J2EE兼容性测试套装一套用于测试J2EE平台产品与J2EE标准兼容性的测试;

◆ J2EE参考实现一组显示J2EE能力的参考实现,也是J2EE平台的选择性定义;

◆ J2EE设计方针这个设计方针描述了用于开发中间层、瘦客户应用的标准编程模式。

Sun公司用J2EE技术实现了三层和多层应用模式,首先,JavaServlet技术允许开发人员创建支持Java平台的、可以在任何Web服务器上运行的、像CGI一样的操作界面。其次,JDBC技术将“写一次,在任何地方运行”的Java编程的功能,与现存数据库管理系统相结合。最后,企业级JavaBean组件结构将完整的一组企业应用逻辑压缩到一个易于配置、可随时重用组件。由于覆盖了这样三个概念:服务端界面用Java编写;可以联接现有的数据库系统;模块化、易于部署的组件,使我们趋向于J2EE标准。

J2EE应用模型

J2EE可以支持传统的企业应用,这些企业应用为客户、雇员、供应商、合作伙伴及其它需要或为企业提供服务的人提供服务。这些应用非常复杂,数据可能从许多地方读取,并且应用分布于各种客户端,应用模型如下图。

为了更好地控制和管理这些应用,支持各种用户的业务功能被连接到中间层,中间层代表着一个被企业信息技术部门紧密控制着的环境。中间层被指定运行在特定的服务器硬件上,并可以涉及企业所有的服务。

J2EE应用模式定义了用于以多层的方式实现应用的一种结构,它避免了两层结构的局限性,并提供足够的可伸缩性、可接入性和可管理性。

  

J2EE应用方式将实现多层服务所需要进行的工作分成两个部分,即为J2EE提供标准的系统服务—业务和表示逻辑。由开发人员完成业务和表示逻辑,开发人员可以依靠这个平台提供的开发中间层服务来解决实现硬件层的方案。

  

J2EE应用模式具有可以执行性和可伸缩性,为多层应用程序提供了“写一次就可在任何地方运行”的优势。在充分选择提供给企业的J2EE服务器和开发工具的情况下,这种标准化的模式将开发和培训的成本降到最低。

  

J2EE应用模式通过降低建造多层应用复杂性,向应用开发的简单化和可扩展化前进了一大步。

展示层

展示层也可以称为表示层,J2EE平台支持几种类型的客户端。许多J2EE服务被设计成支持Web浏览器的客户端。这些服务通过动态生成的HTML页面和表格与客户端进行交互操作。

  

更复杂的服务将直接与第一层客户端直接交换数据。这里,JSP和Servlet用于规格化业务数据,以方便J2EE客户端处理。这些客户端既能在一个Web浏览器以JavaApplet方式运行,也能用以Java技术为基础的程序方式运行。

中间层

使用J2EE应用模式的主要优点在于多层应用的中间层。在J2EE平台,中间层业务功能是由企业JavaBean(EJB)组件实现。这些企业Bean让服务开发者将精力集中在业务逻辑,并让EJB服务的处理提供可靠、可伸缩服务的复杂工作。EJB组件将业务逻辑在中间层实现,如下

JavaServer Pages(JSP)技术和Servlet是使用Internet模式为表示层表现中间层的功能。JSP技术使用户界面开发工作变得容易,可以为浏览器提供页面的动态生成技术。Servlet给以Java技术为基础的应用程序开发者提供了一种手段,可以用Java语言完整地实现动态表示。

中间层一般用到的企业服务有事务服务(JTA)、目录服务(JNDI)、消息服务(JMS)、异步组件(Message-DrivenEJB)、远程调用(RMI/IIOP)。

企业信息层

一个服务的中间层的业务模块必须存取和更新在企业信息层(EIS)的信息。下列标准是Java服务的API,它们提供了对企业信息系统的基本存取功能:

◆JDBC,用于存取数据的Java标准API;

◆ JNDI(Java Namingand Directory Interface),查找和访问各种命名和目录服务的通用、统一的标准API;

◆ JMS(Java MessageService),通过消息中间件发送和接收信息的标准API;

◆JavaMail,发送电子邮件的标准API;

◆JavaIDL,调用CORBA服务的标准API。

J2EE应用服务器中间件的体系结构

J2EE应用服务器总体结构

J2EE应用服务器由四个部分组成:Applet容器、应用客户端容器、Web容器和EJB容器,它们之间的关系如下图表示。但是,图中所表示的是各个部件间的逻辑结构,这并不意味着这些部件必须物理地被分布在不同的机器上、不同的处理器上、不同的地址空间中和不同的虚拟机上。

容器是应用服务器的运行环境,J2EE为容器中的应用组件提供服务,每种容器根据各自的应用组件不同,提供不同类型的服务。它们涉及到各个方面,为组件的运行提供必要的支持。但是,不同容器中相同的服务为应用组件提供的接口是相同的。图中的箭头表示了对于应用服务器的其它部分的存取。应用客户端容器通过用于连接数据库系统的JavaAPI、JDBCAPI与应用服务器要求的数据库相连接。包含有JSP和Servlet的Web容器和EJB容器也使用同样的接口与数据库相连接。容器中的每种组件都由J2SE的运行环境提供支持。

J2EE应用组件是指在应用服务器中运行的软件组件,主要有JSP、EJB和Servlet三种,它们在应用服务器中被部署、管理和执行。。

J2EE应用服务器体系结构

从图中看出,应用服务器的核心是基于微内核的也就是java虚拟机(JVM)。应用服务器的JVM提供了底层的通信、线程、配置、时间、日志等核心功能。在微内核之上,遵循J2EE标准实现各种服务。应用在这种JVM的设计模式,使上层标准的服务实现与底层的系统资源管理分离,保持了软件模块间松散耦合的优点。同时,应用服务器还提供了专门的服务接口,允许客户不必局限在J2EE的框架中,直接在JVM层次上开发针对于具体案例的系统服务,特别适合于有特殊需求的应用系统。

J2EE.NET的比较

通过两张图来比较下它们的不同,

通过两张图,我们可以发现.Net和J2EE应用有着相似的架构,有相应的主要技术,不同的是.Net所有技术来自Microsoft,而J2EE的技术有多个厂商的实现。


J2EE技术


.NET技术


JDBC


ADO.NET


JTA


.NET Transaction


JNDI


Active Directory


JMS


.NET Messaging


JavaMail


SmtpMail


RMI/IIOP


Web Service/Remoting


JAF


.NET JIT

.Net和J2EE可以满足大多数应用的需求,只是两种不同的实现方式而已,它们主要的差别补在技术的可行性上,只是在开发效率、性能、成本和稳定性上有所差异而已。

后记

通过这几篇文章对中间件的介绍,我们了解了中间件的基本概念、中间件技术的具体分类内容、中间件的主流技术平台最后又对J2EE与.NET技术进行了比较。

时间: 2024-08-25 06:56:26

中间件学习——J2EE中间件四步曲的相关文章

中间件学习——初识篇

最近这段时间正在学习中间件的内容,从这篇文章开始我们开始学习中间件的相关内容. 发展概述 在学习中间件知识之前我们先了解下软件开发技术的发展,从软件开发技术的一步步发展中慢慢的衍生出了中间件的技术,现在我们开始依次介绍软件开发技术的发展. 1.基于主机的系统 基于主机的系统最开始的时候是只有硬件和程序组成的,这时候的程序还没有分操作系统和应用程序,经过长时间的发展,人们慢慢的发现程序中有稳定的成分那就是计算资源管理这部分,人们根据程序的稳定成分也可以说是共性成分,这部分共性成分也就是操作系统,人

关于中间件、J2EE的一些概念

本文主要针对Java EE涉及的一些概念做一些整理. ------------------------------------------------------------------------------- 1.中间件 中间件是企业级开发中常用的术语,一听貌似很难懂,不着急,我们就解决两个问题: 为什么需要中间件? 什么是中间件? 早先企业级应用程序的体系结构为两层体系结构,两层体系结构分为客户层与服务器层,即常常被提到的C/S模式. 在C/S模式中,客户层几乎包揽了除数据服务之外的其他所

中间件学习——二步曲(分类)

上一篇文章我们介绍了中间件的由来.定义和作用,这篇文章我们继续中间件的学习,中间件的产品种类很多,根据中间件在系统中所起的作用和采用的技术不同,我们将中间件进行了分类,我们今天就详细学习下中间件具体知识. 分类 中间件分为远程过程调用中间件.数据访问中间件.消息中间件.事务(交易)处理中间件.分布式对象中间件. 远程过程调用中间件(RPC, Remote Procedure Call) 我们一个一个来学习,首先来学习的是远程过程调用中间件,远程过程调用就是程序和程序之间的通信,就是客户端应用程序

scrapy 爬虫学习二[中间件的学习]

scrapy源码解析参考连接:https://www.jianshu.com/p/d492adf17312 ,直接看大佬的就行了,这里便就不多说了. 今天要学习的是:Scrapy框架中的download middlerware[下载中间件]用法. 一:官方文档中,对下载中间件的解释如下 下载中间件是介于scrapy的requests/response处理的钩子框架,是用于全局修改scrapy requests和response的一个轻量.底层的系统. 二:使用下载器中间件时必须激活这个中间件,方

ASP.NET Core WebApi AspNetCoreRateLimit 限流中间件学习

原文:ASP.NET Core WebApi AspNetCoreRateLimit 限流中间件学习 AspNetCoreRateLimit介绍: AspNetCoreRateLimit是ASP.NET核心速率限制框架,能够对WebApi,Mvc中控制限流,AspNetCoreRateLimit包包含IpRateLimit中间件和ClientRateLimit中间件,每个中间件都可以为不同的场景设置多个限,该框架的作者是stefanprodan,项目nuget地址是https://github.

laravel5学习之中间件访问控制

如果控制文章的添加只有登录的用户才可以操纵,可以加判断如下 public function create(){ //这个虽然可以达到控制登陆用户访问的目的 但是需要写很多 if(Auth::guest()){ return redirect('auth/login'); } return view('articles.create'); } 文件Http-->Middleware-->Authenticate.php就是对应的权限控制文件,在Http-->Kernel.php中有如下代码

Django 学习之中间件Middleware

一.中间件介绍 中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出.因为改变的是全局,所以需要谨慎实用,用不好会影响到性能. Django的中间件官方的定义: Middleware is a framework of hooks into Django’s request/response processing. <br>It’s a light, low-level “plugin” system for g

Java前辈:学习J2EE流程中的经验和教训

Java前辈:学习J2EE流程中的经验和教训 在这里我谈谈我在学习j2ee流程,并谈到在此过程中领会的经验和教训.以便后来者少走弯路. Java发展到现在,按应用来分主要分为三大块:J2SE,J2ME和J2EE.这三块相互补充,应用范围不同. J2SE就是Java2的标准版,主要用于桌面应用软件的编程: J2ME主要应用于嵌入是系统开发,如手机和PDA的编程: J2EE是Java2的企业版,主要用于分布式的网络程序的开发,如电子商务网站和ERP系统. 先学习j2se 要学习j2ee就要先学习j2

中间件学习——技术平台三步曲

在前面两篇文章中,我们了解了中间件的基本概念和中间件的主要技术分类,在这篇文章中我们了解下基于中间件的主流技术平台. 技术平台 现有的基于中间件的主流技术平台一般典型的应用是为三层/多层结构的分布式软件系统提供各种开发支撑,因为三层结构的分布式软件的核心为中间层,因此支撑主要集中在对中间层开发的支撑上,目前应该最广泛的技术平台有三类: 基于 OMG(ObjectManagement Group,对象管理组织)CORBA规范 基于 Sun JEE(JavaEnterprise Edition,Ja