J2EE是一套全然不同于传统套用开发的技术架构,包含许多组件,主要可简化且规范套用系统的开发与部署,进而提高可移植性、安全与再用价值。
J2EE核心是一组技术规范与指南,其中所包含的各类组件、服务架构及技术层次,均有共同的标準及规格,让各种依循J2EE架构的不同平台之间,存在良好的兼容性,解决过去企业后端使用的信息产品彼此之间无法兼容,企业内部或外部难以互通的窘境。
J2EE组件和“标準的” Java类的不同点在于它被装配在一个J2EE套用中,具有固定的格式并遵守J2EE规范,由J2EE伺服器对其进行管理。J2EE规范是这样定义J2EE组件的客户端应用程式和applet是运行在客户端的组件;Java Servlet和Java Server Pages (JSP) 是运行在伺服器端的Web组件;Enterprise Java Bean (EJB )组件是运行在伺服器端的业务组件。
基本介绍
- 中文名Java2平台企业版
- 外文名Java 2 Platform Enterprise Edition
- 简称J2EE
- 功能提高可移植性、安全与再用价值
简介
J2EE(Java 2 Platform, Enterprise Edition)是一个为大企业主机级的计算类型而设计的Java平台。Sun微系统(与其工业伙伴一起,例如IBM)设计了J2EE,以此来简化在受客户级环境下的套用开发。由于创造了标準的可重用模组组件以及由于构建出能自动处理编程中多方面问题的等级结构,J2EE简化了应用程式的开发,也降低了对编程和对受训的程式设计师的要求。
发展背景
1、 企业级套用框架的需求在许多企业级套用中,例如资料库连线、邮件服务、事务处理等都是一些通用企业需求模组,这些模组如果每次在开发中都由开发人员来完成的话,将会造成开发周期长和代码可靠性差等问题。于是许多大公司开发了自己的通用模组服务。这些服务性的软体系列统称为中间件。
2、 为了通用必须要提出规范,不然无法达到通用
在上面的需求基础之上,许多公司都开发了自己的中间件,但其与用户的沟通都各有不同,从而导致用户无法将各个公司不同的中间件组装在一块为自己服务。从而产生瓶颈。于是提出标準的概念。其实J2EE就是基于JAVA技术的一系列标準。
注中间件处在作业系统和更高一级应用程式之间。它充当的功能是将应用程式运行环境与作业系统隔离,从而实现应用程式开发者不必为更多系统问题忧虑,而直接关注该应用程式在解决问题上的能力。容器的概念就是中间件的一种。
Sun公司在1998年发表JDK1.2版本的时候, 使用了新名称Java 2 Platform,即“Java2平台”,修改后的JDK称为Java 2 Platform Software Develping Kit,即J2SDK。并分为标準版(Standard Edition,J2SE), 企业版(Enterprise Edition,J2EE),微型版(MicroEdition,J2ME)。J2EE便由此诞生。
2005年6月,JavaOne大会召开,SUN公司公开Java SE 6。此时,Java的各种版本已经更名以取消其中的数字“2”J2EE更名为Java EE, J2SE更名为Java SE,J2ME更名为Java ME。
Java2平台包括标準版(J2SE)、企业版(J2EE)和微缩版(J2ME)三个版本。
优势
J2EE为搭建具有可伸缩性、灵活性、易维护性的商务系统提供了良好的机制
1. 保留现存的IT资产
由于企业必须适应新的商业需求,利用已有的企业信息系统方面的投资,而不是重新制定全盘方案就变得很重要。这样,一个以渐进的(而不是激进的,全盘否定的)方式建立在已有系统之上的伺服器端平台机制是公司所需求的。J2EE架构可以充分利用用户原有的投资,如一些公司使用的BEA Tuxedo、IBM CICS,IBM Encina,、Inprise VisiBroker 以及Netscape Application Server。这之所以成为可能是因为J2EE拥有广泛的业界支持和一些重要的'企业计算'领域供应商的参与。每一个供应商都对现有的客户提供了不用废弃已有投资,进入可移植的J2EE领域的升级途径。由于基于J2EE平台的产品几乎能够在任何作业系统和硬体配置上运行,现有的作业系统和硬体也能被保留使用。
2. 高效的开发
J2EE允许公司把一些通用的、很繁琐的服务端任务交给中间供应商去完成。这样开发人员可以集中精力在如何创建商业逻辑上,相应地缩短了开发时间。高级中间件供应商提供以下这些複杂的中间件服务
o 状态管理服务 -- 让开发人员写更少的代码,不用关心如何管理状态,这样能够更快地完成程式开发。
o 持续性服务 -- 让开发人员不用对数据访问逻辑进行编码就能编写应用程式,能生成更轻巧,与资料库无关的应用程式,这种应用程式更易于开发与维护。
o 分散式共享数据对象CACHE服务 -- 让开发人员编制高性能的系统,极大提高整体部署的伸缩性。
3. 支持异构环境
J2EE能够开发部署在异构环境中的可移植程式。基于J2EE的应用程式不依赖任何特定作业系统、中间件、硬体。设计合理的基于J2EE的程式只需开发一次就可部署到各种平台。这在典型的异构企业计算环境中是十分关键的。J2EE标準也允许客户订购与J2EE兼容的第三方的现成的组件,把他们部署到异构环境中,节省了由自己制订整个方案所需的费用。
4. 可伸缩性
企业必须要选择一种伺服器端平台,这种平台应能提供极佳的可伸缩性去满足那些在他们系统上进行商业运作的大批新客户。基于J2EE平台的应用程式可被部署到各种作业系统上。例如可被部署到高端UNIX与大型机系统,这种系统单机可支持64至256个处理器。(这是NT伺服器所望尘莫及的)J2EE领域的供应商提供了更为广泛的负载平衡策略,能消除系统中的瓶颈,允许多台伺服器集成部署。这种部署可达数千个处理器,实现可高度伸缩的系统,满足未来商业套用的需要。
5.稳定的可用性
一个伺服器端平台必须能全天候运转以满足公司客户、合作伙伴的需要。因为INTERNET是全球化的、无处不在的,即使在夜间按计画停机也可能造成严重损失。若是意外停机,那会有灾难性后果。J2EE部署到可靠的操作环境中,他们支持长期的可用性。一些J2EE部署在WINDOWS环境中,客户也可选择鲁棒性(稳定性)更好的作业系统如Sun Solaris、IBM OS/390。鲁棒性最好的作业系统可达到99.999%的可用性或每年只需5分钟停机时间。这是实时性很强商业系统理想的选择。
结构
这种基于组件,具有平台无关性的J2EE 结构使得J2EE 程式的编写十分简单,因为业务逻辑被封装成可复用的组件,并且J2EE 伺服器以容器的形式为所有的组件类型提供后台服务。因为你不用自己开发这种服务,所以你可以集中精力解决手头的业务问题。
容器和服务容器设定定製了J2EE伺服器所提供的内在支持,包括安全,事务管理,JNDI(Java Naming and Directory Interface)定址,远程连线等服务,以下列出最重要的几种服务
J2EE安全(Security)模型可以让你配置 web 组件或enterprise bean,这样只有被授权的用户才能访问系统资源. 每一客户属于一个特别的角色,而每个角色只允许激活特定的方法。你应在enterprise bean的布置描述中声明角色和可被激活的方法。由于这种声明性的方法,你不必编写加强安全性的规则。
J2EE 事务管理(Transaction Management)模型让你指定组成一个事务中所有方法间的关係,这样一个事务中的所有方法被当成一个单一的单元. 当客户端激活一个enterprise bean中的方法,容器介入一管理事务。因有容器管理事务,在enterprise bean中不必对事务的边界进行编码。要求控制分散式事务的代码会非常複杂。你只需在布置描述档案中声明enterprise bean的事务属性,而不用编写并调试複杂的代码。容器将读此档案并为你处理此enterprise bean的事务。JNDI 定址(JNDI Lookup)服务向企业内的多重名字和目录服务提供了一个统一的接口,这样应用程式组件可以访问名字和目录服务。
J2EE远程连线(Remote Client Connectivity)模型管理客户端和enterprise bean间的低层互动。当一个enterprise bean创建后,一个客户端可以调用它的方法就象它和客户端位于同一虚拟机上一样。
生存周期管理(Life Cycle Management)模型管理enterprise bean的创建和移除,一个enterprise bean在其生存周期中将会历经几种状态。容器创建enterprise bean,并在可用实例池与活动状态中移动他,而最终将其从容器中移除。即使可以调用enterprise bean的create及remove方法,容器也将会在后台执行这些任务。
资料库连线池(Database Connection Pooling)模型是一个有价值的资源。获取资料库连线是一项耗时的工作,而且连线数非常有限。容器通过管理连线池来缓和这些问题。enterprise bean可从池中迅速获取连线。在bean释放连线之后可为其他bean使用。
容器类型
J2EE套用组件可以安装部署到以下几种容器中去
EJB 容器管理所有J2EE 应用程式中企业级bean 的执行。enterprise bean 和它们的容器运行在J2EE 伺服器上。
Web 容器管理所有J2EE 应用程式中JSP页面和Servlet组件的执行。 Web 组件和它们的容器运行在J2EE 伺服器上。应用程式客户端容器管理所有J2EE应用程式中应用程式客户端组件的执行。应用程式客户端和它们的容器运行在J2EE 伺服器上。Applet 容器是运行在客户端机器上的web浏览器和 Java 外挂程式的结合。
区别
J2EE是Java 2 enterprise edition是Java的一种企业版用于企业级的套用服务开发
J2SE是Java 2 standard edition是Java的标準版,用于标準的套用开发
J2ME是Java 2 Micro Edition是Java的微型版,常用于手机上的开发
J2EE,J2SE,J2ME是java针对不同的的使用来提供不同的服务,也就是提供不同类型的类库。
四层模型
J2EE使用多层的分散式套用模型,套用逻辑按功能划分为组件,各个套用组件根据他们所在的层分布在不同的机器上。事实上,sun设计J2EE的初衷正是为了解决两层模式(client/server)的弊端,在传统模式中,客户端担当了过多的角色而显得臃肿,在这种模式中,第一次部署的时候比较容易,但难于升级或改进,可伸展性也不理想,而且经常基于某种专有的协定,通常是某种资料库协定。它使得重用业务逻辑和界面逻辑非常困难。现在J2EE 的多层企业级套用模型将两层化模型中的不同层面切分成许多层。一个多层化套用能够为不同的每种服务提供一个独立的层,以下是 J2EE 典型的四层结构
运行在客户端机器上的客户层组件
运行在J2EE伺服器上的Web层组件
运行在J2EE伺服器上的业务逻辑层组件
运行在EIS伺服器上的企业信息系统(Enterprise information system)层软体
J2EE应用程式组件
J2EE应用程式是由组件构成的.J2EE组件是具有独立功能的软体单元,它们通过相关的类和档案组装成J2EE应用程式,并与其他组件互动。J2EE说明书中定义了以下的J2EE组件
套用客户端程式和applets是客户层组件.
Java Servlet和JavaServer Pages(JSP)是web层组件.
Enterprise JavaBeans(EJB)是业务层组件.
客户层组件
J2EE应用程式可以是基于web方式的,也可以是基于传统方式的.
web 层组件
J2EE web层组件可以是JSP 页面或Servlets.按照J2EE规范,静态的HTML(标準通用标记语言下的一个套用)页面和Applets不算是web层组件。
正如下图所示的客户层那样,web层可能包含某些 JavaBean 对象来处理用户输入,并把输入传送给运行在业务层上的enterprise bean 来进行处理。
业务层组件
业务层代码的逻辑用来满足银行,零售,金融等特殊商务领域的需要,由运行在业务层上的enterprise bean 进行处理. 下图表明了一个enterprise bean 是如何从客户端程式接收数据,进行处理(如果必要的话),并传送到EIS 层储存的,这个过程也可以逆向进行。
有三种企业级的bean: 会话(session) beans,实体(entity) beans,和讯息驱动(message-driven) beans. 会话bean 表示与客户端程式的临时互动. 当客户端程式执行完后,会话bean 和相关数据就会消失. 相反,实体bean 表示资料库的表中一行永久的记录. 当客户端程式中止或伺服器关闭时,就会有潜在的服务保证实体bean 的数据得以保存.讯息驱动 bean 结合了会话bean 和 JMS的讯息监听器的特性,允许一个业务层组件异步接收JMS 讯息.
信息系统层
企业信息系统层处理企业信息系统软体包括企业基础建设系统例如企业资源计画(ERP),大型机事务处理,资料库系统,和其它的遗留信息系统. 例如,J2EE 套用组件可能为了资料库连线需要访问企业信息系统。
组件标準规范
J2EE平台由一整套服务(Services)、应用程式接口(APIs)和协定构成,它对开发基于Web的多层套用提供了功能支持,下面对J2EE中的13种技术规范进行简单的描述(限于篇幅,这里只能进行简单的描述)
1:JDBC(Java Database Connectivity)
JDBC API为访问不同资料库提供了统一的路径,像ODBC一样,JDBC开发者禁止了一些细节问题,,JDBC对资料库的访问也具有平台无关性.
2:JNDI(Java Naming and Directory Interface)
JNDI API 被用于执行名字和目录服务.它提供了一致的模型来存取和操作企业级的资源DNS和LDAP,本地档案系统,或套用伺服器中的对象.
3:EJB(Enterprise JavaBean)
J2EE技术之所以赢得广泛重视的原因之一就是EJB.它提供了一个框架来开发和实施分散式商务逻辑,由此很显着的简化了具有可伸缩性和高度複杂的企业级应用程式的开发.EJB规范定义了EJB组件在何时如何与它们的容器进行互动作用.容器负责提供公用的服务,例如目录服务,事务管理,安全性,资源缓冲池以及容错性.但这里值得注意的是,EJB并不是实现J2EE的唯一路径.正是由于J2EE的开放性,使得所有的厂商能够以一种和EJB平行的方式来达到同样的目地.
4:RMI(Remote Method Invoke)
远程方法请求,RMI协定调用远程对象上的方法.它使用了序列化的方式在客户端和伺服器之间传递数据.RMI是一种被EJB使用的更底层的协定.
5:Java IDL/CORBA(通用对象请求代理架构是软体构建的一个标準 )
在Java IDL的支持下,开发人员可以将Java和CORBA集成在一起.他们可以创建Java对象并使之可在CORBA ORB中展开,或者他们还可以创建Java类并和其它ORB一起展开的CORBA对象客户.后一种方法提供了一种途径,通过它Java可以被用于将你的新的应用程式和旧的系统集合在一起.
6:JSP
JSP页面由HTML(标準通用标记语言下的一个套用)代码和嵌入其中的Java代码组成.伺服器在
页面被客户端所请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端浏览器.
7:Java Servlet
Servlet 是一种小型的Java程式,它扩展了web伺服器的功能.作为一种伺服器的套用,当被请求时开始执行,这和CGI Perl脚本很相似.Servlet提供的功能大多和JSP类似,不过实现的方式不同.JSP通常是大多数的HTML代码中嵌入少量的Java代码,而servlet全部由java写成并且生成HTML.
8:XML
XML(标準通用标记语言的子集)是一种可以用来定其它标记语言的语言.它被用来在不同的商务过程中共享数据.XML的发展和java是相互独立的,,它和java具有的相同目标是平台独立性.
9:JMS
MS是用于和面向对象讯息的中间件相互通信的应用程式接口.它既支持点对点的域,又支持发布/订阅类型的域,并且提供了下列类型的支持:讯息传递,事务型讯息的传递,一致性讯息和具有持久性的订阅者支持.JMS还提供了另一种方式来对新系统和旧后台系统相互集成.
10:JTA
JTA定义了一种标準API,应用程式由此可以访问各种事务监控.
11:JTS
JTS是CORBA OTS事务监控的基本实现.JTS规定了事务管理的实现方法.该事务管理器是在高层支持java Transaction API规范,并且在较低层次实现OMG OTS specification 和Java对象.JTS事务管理器为应用程式伺服器,资源管理器,独立的套用以及通信资源管理器提供了事务服务.
12:JavaMail
JavaMail是用于存取邮件伺服器的API,它提供了一套邮件伺服器的抽象类.不仅支持SMTP伺服器,也支持IMAP伺服器.
13:JAF(JavaBeans Activation Framework)
JAVA安全认证框架。提供一些安全控制方面的框架。让开发者通过各种部署和自定义实现自己的个性安全控制策略。
名词解释
容器充当中间件的角色。
WEB容器给处于其中的应用程式组件(JSP,SERVLET)提供一个环境,使JSP,SERVLET直接与容器中的环境变数接口互动,不必关注其它系统问题。主要由WEB伺服器来实现。例如TOMCAT,WEBLOGIC,WEBSPHERE等。该容器提供的接口严格遵守J2EE规范中的WEB APPLICATION 标準。我们把遵守以上标準的WEB伺服器就叫做J2EE中的WEB容器。
EJB容器Enterprise java bean 容器。更具有行业领域特色。他提供给运行在其中的组件EJB各种管理功能。只要满足J2EE规范的EJB放入该容器,马上就会被容器进行高效率的管理。并且可以通过现成的接口来获得系统级别的服务。例如邮件服务、事务管理。
WEB容器和EJB容器在原理上是大体相同的,更多的区别是被隔离的外界环境。WEB容器更多的是跟基于HTTP的请求打交道。而EJB容器不是。它是更多的跟资料库、其它服务打交道。但他们都是把与外界的互动实现从而减轻应用程式的负担。例如SERVLET不用关心HTTP的细节,直接引用环境变数session,request,response就行、EJB不用关心资料库连线速度、各种事务控制,直接由容器来完成。
RMI/IIOP远程方法调用internet对象请求中介协定,他们主要用于通过远程调用服务。例如,远程有一台计算机上运行一个程式,它提供股票分析服务,我们可以在本地计算机上实现对其直接调用。这是要通过一定的规范才能在异构的系统之间进行通信。RMI是JAVA特有的。
JNDI:JAVA命名目录服务。主要提供的功能是提供一个目录系统,让其它各地的应用程式在其上面留下自己的索引,从而满足快速查找和定位分散式应用程式的功能。
JMS:JAVA讯息服务。主要实现各个应用程式之间的通讯。包括点对点和广播。
JAVAMAIL:JAVA邮件服务。提供邮件的存储、传输功能。他是编程中实现邮件功能的核心。相当MS中的EXCHANGE开发包。
JTAJAVA事务服务。提供各种分散式事务服务。应用程式只需调用其提供的接口即可。
JAAS:JAVA安全认证框架。提供一些安全控制方面的框架。让开发者通过各种部署和自定义实现自己的个性安全控制策略。
EAI:企业套用集成。是一种概念,从而牵涉到好多技术。J2EE技术是一种很好的集成实现。
核心技术
为了联繫实际,GOULD基于WEBLOGIC套用伺服器(来自BEASYSTEMS公司的一种广为套用的产品)环境来介绍J2EE的这些技术。JAVA最初是在浏览器和客户端机器中闪亮登场的。当时,很多人质疑它是否适合做伺服器端的开发。随着对JAVA2平台企业版(J2EE)第三方支持的增多,JAVA被广泛接纳为开发企业级伺服器端解决方案的首选平台之一。
J2EE平台由一整套服务(SERVICES)、应用程式接口(APIS)和协定构成,它对开发基于WEB的多层套用提供了功能支持。在本文中我将解释支撑J2EE的13种核心技术JDBC,JNDI,EJBS,RMI,JSP,JAVA SERVLETS,XML,JMS,JAVA IDL,JTS,JTA,JAVA MAIL 和 JAF,还将描述在何时、何处需要使用这些技术。,我还要介绍这些不同的技术之间是如何互动的。,为了让您更好地感受J2EE的真实套用,我将在WEBLOGIC套用伺服器(来自BEA SYSTEMS公司的一种广为套用的产品)环境下来介绍这些技术。不论对于WEBLOGIC套用伺服器和J2EE的新手,还是那些想了解J2EE能带来什幺好处的项目管理者和系统分析员,相信本文一定很有参考价值。
巨观印象 分散式结构和J2EE
过去,二层化套用--通常被称为CLIENT/SERVER套用--是大家谈论的最多的。在很多情况下,伺服器提供的唯一服务就是资料库服务。在这种解决方案中,客户端程式负责数据访问、实现业务逻辑、用合适的样式显示结果、弹出预设的用户界面、接受用户输入等。CLIENT/SERVER结构通常在第一次部署的时候比较容易,但难于升级或改进,而且经常基于某种专有的协定(通常是某种资料库协定)。它使得重用业务逻辑和界面逻辑非常困难。更重要的是,在WEB时代,二层化套用通常不能体现出很好的伸缩性,因而很难适应INTERNET的要求。
SUN设计J2EE的部分起因就是想解决二层化结构的缺陷。于是J2EE定义了一套标準来简化N层企业级套用的开发。它定义了一套标準化的组件,并为这些组件提供了完整的服务。J2EE还自动为应用程式处理了很多实现细节,如安全、多执行绪等。用J2EE开发N层套用包括将二层化结构中的不同层面切分成许多层。一个N层化套用A能够为以下的每种服务提供一个分开的层显示在一个典型的WEB套用中,客户端机器上运行的浏览器负责实现用户界面。
动态生成显示 儘管浏览器可以完成某些动态内容显示,但为了兼容不同的浏览器,这些动态生成工作应该放在WEB伺服器端进行,使用JSP、SERVLETS,或者XML(标準通用标记语言下的一个子集可扩展标记语言)和XSL(可扩展样式表语言)。
业务逻辑业务逻辑适合用SESSION EJB(后面将介绍)来实现。
数据访问数据访问适合用ENTITY EJB(后面将介绍)和JDBC来实现 。
后台系统集成 后台系统的集成可能需要用到许多不同的技术,至于何种最佳需要根据后台系统的特徵而定。
您可能开始诧异为什幺有这幺多的层?事实上,多层方式可以使企业级套用具有很强的伸缩性,它允许每层专注于特定的角色。例如,让WEB伺服器负责提供页面,套用伺服器处理套用逻辑,而资料库伺服器提供资料库服务。
由于J2EE建立在JAVA2平台标準版(J2SE)的基础上,所以具备了J2SE的所有优点和功能。包括“编写一次,到处可用”的可移植性、通过JDBC访问资料库、同原有企业资源进行互动的CORBA技术以及一个经过验证的安全模型。在这些基础上,J2EE又增加了对EJB(企业级JAVA组件)、JAVA SERVLETS、JAVA伺服器页面(JSPS)和XML(标準通用标记语言的子集)技术的支持。
分散式结构与WEBLOGIC套用伺服器
J2EE提供了一个框架--一套标準API--用于开发分散式结构的套用,这个框架的实际实现留给了第三方厂商。部分厂商只是专注于整个J2EE架构中的的特定组件,例如APACHE的TOMCAT提供了对JSP和SERVLETS的支持,BEA系统公司则通过其WEBLOGIC套用伺服器产品为整个 J2EE规范提供了一个较为完整的实现。
WEBLOGIC伺服器已使建立和部署伸缩性较好的分散式套用的过程大为简化。WEBLOGIC和J2EE代理处理了大量常规的编程任务,包括提供事务服务、安全领域、可靠的讯息、名字和目录服务、资料库访问和连线池、执行绪池、负载平衡和容错处理等。通过以一种标準、易用的方式提供这些公共服务,像WEBLOGIC伺服器这样的产品造就了具有更好伸缩性和可维护性的套用系统,使其为大量的用户提供了增长的可用性。
J2EE技术在接下来的部分里,我们将描述构成J2EE的各种技术,并且了解WEBLOGIC伺服器是如何在一个分散式套用中对它们进行支持的。最常用的J2EE技术应该是JDBC、JNDI、EJB、JSP和SERVLETS,对这些我们将作更仔细的考察。
JAVA DATABASE CONNECTIVITY (JDBC)
JDBC API以一种统一的方式来对各种各样的资料库进行存取。和ODBC一样,JDBC为开发人员隐藏了不同资料库的不同特性。,由于JDBC建立在JAVA的基础上,还提供了资料库存取的平台独立性。
JDBC定义了4种不同的驱动程式,现分述如下
类型 1: JDBC-ODBCBRIDGE
在JDBC出现的初期,JDBC-ODBC桥显然是非常有实用意义的,通过JDBC-ODBC桥,开发人员可以使用JDBC来存取ODBC数据源。不足的是,他需要在客户端安装ODBC驱动程式,换句话说,必须安装MICROSOFT WINDOWS的某个版本。使用这一类型你需要牺牲JDBC的平台独立性。,ODBC驱动程式还需要具有客户端的控制许可权。
类型 2: JDBC-NATIVE DRIVER BRIDGE
JDBC本地驱动程式桥提供了一种JDBC接口,它建立在本地资料库驱动程式的顶层,而不需要使用ODBC。JDBC驱动程式将对资料库的API从标準的JDBC调用转换为本地调用。使用此类型需要牺牲JDBC的平台独立性,还要求在客户端安装一些本地代码。
类型 3: JDBC-NETWORK BRIDGE
JDBC网路桥驱动程式不再需要客户端资料库驱动程式。它使用网路上的中间伺服器来存取资料库。这种套用使得以下技术的实现有了可能,这些技术包括负载 均衡、连线缓冲池和数据快取等。由于第3种类型往往只需要相对更少的下载时间,具有平台独立性,而且不需要在客户端安装并取得控制权,所以很适合于 INTERNET上的套用。
类型 4: PURE JAVA DRIVER
第4种类型通过使用一个纯JAVA资料库驱动程式来执行资料库的直接访问。此类型实际上在客户端实现了2层结构。要在N-层结构中套用,一个更好的做法是编写一个EJB,让它包含存取代码并提供一个对客户端具有资料库独立性的服务。
WEBLOGIC伺服器为一些通常的资料库提供了JDBC驱动程式,包括ORACLE,SYBASE,MICROSOFT SQLSERVER以及INFORMIX。它也带有一种JDBC驱动程式用于CLOUDSCAPE,这是一种纯JAVA的DBMS,WEBLOGIC伺服器中带有该资料库的评估版本。
以下让我们看一个实例。
JDBC实例在这个例子中我们假定你已经在CLOUDSCAPE中建立了一个PHONEBOOK资料库,并且包含一个表,名为CONTACT_TABLE ,它带有2个栏位NAME 和 PHONE。开始的时候先装载CLOUDSCAPE JDBC DRIVER,并请求DRIVER MANAGER得到一个对PHONEBOOK CLOUDSCAPE资料库的连线。通过这一连线,我们可以构造一个STATEMENT 对象并用它来执行一个简单的SQL查询。,用循环来遍历结果集的所有数据,并用标準输出将NAME和PHONE栏位的内容进行输出。
importjava.sql.;publicclassjdbcexample{publicstaticvoidmain(stringargs[]){try{class.forname("com.cloudscape.core.jdbcdriver");connectionconn=drivermanager.getconnection("jdbc:cloudscape:phonebook");statementstmt=conn.createstatement();stringsql="selectname,phonefromcontact_tableorderbyname";resultsetresultset=stmt.executequery(sql);stringname;stringphone;while(resultset.next()){name=resultset.getstring(1).trim();phone=resultset.getstring(2).trim();system.out.println(name+","+phone);}}catch(exceptione){//handleexceptionheree.printstacktrace();}}}
OK。接着我们来看一看JDBC是如何在企业套用中的进行使用。JDBC在企业级套用中的套用以上实例其实是很基本的,可能有些微不足道。它假定了一个2层结构。在一个多层的企业级套用中,更大的可能是在客户端和一个EJB进行通信,该EJB将建立资料库连线。为了实现和改进可伸缩性和系统性能,WEBLOGIC伺服器提供了对连线缓冲池CONNECTION POOL的支持。CONNECTION POOL减少了建立和释放资料库连线的消耗。在系统启动以后即可建立这样的缓冲池,此后如故再有对资料库的请求,WEBLOGIC伺服器可以很简单地从缓 沖池中取出数据。数据缓冲池可以在WEBLOGIC伺服器的WEBLOGIC.PROPERTIES 档案中进行定义。(可参考 WEBLOGIC.PROPERTIES 档案中的例子,WEBLOGIC伺服器的文档中还有更详细的参考信息)在企业级套用的另一 个常见的资料库特性是事务处理。事务是一组申明STATEMENT,它们必须做为同一个STATEMENT来处理以保证数据完整性。预设情况下JDBC使 用 AUTO-COMMIT 事务模式。这可以通过使用CONNECTION类的 SETAUTOCOMMIT() 方法来实现。
现在我们已经对JDBC有了一些认识,下面该转向JNDI了。
JAVA NAMING AND DIRECTORY INTERFACE (JNDI)
JNDI API被用于执行名字和目录服务。它提供了一致的模型来存取和操作企业级的资源如DNS和LDAP,本地档案系统,后者在套用伺服器中的对象。
在JNDI中,在目录结构中的每一个结点称为CONTEXT。每一个JNDI名字都是相对于CONTEXT的。这里没有绝对名字的概念存在。对一个套用来说,它可以通过使用 INITIALCONTEXT 类来得到其第一个CONTEXT:
CONTEXT CTX = NEW INITIALCONTEXT();
套用可以通过这个初始化的CONTEXT经有这个目录树来定位它所需要的资源或对象。例如,假设你在WEBLOGIC伺服器中展开了一个EJB并将 HOME接口绑定到名字 MYAPP.MYEJB ,那幺该EJB的某个客户在取得一个初始化
CONTEXT以后,可以通过以下语句定位HOME接口
MYEJBHOME HOME = CTX.LOOKUP( "MYAPP.MYEJB" );
在这个例子中,一旦你有了对被请求对象的参考,EJB的HOME接口就可以在它上面调用方法。我们将在下面的"ENTERPRISE JAVA BEANS"章节中做更多的介绍。
以上关于JNDI的讨论只是冰山之一角而已。如果要更进一步地在CONTEXT中查找对象,JNDI也提供了一些方法来进行以下操作
将一个对象插入或绑定到CONTEXT。这在你展开一个EJB的时候是很有效的。
从CONTEXT中移去对象。
列出CONTEXT中的所有对象。
创建或删除子一级的CONTEXT。
接下来,我们要开始关注EJB了。
ENTERPRISE JAVA BEANS (EJB)
J2EE技术之所以赢得媒体广泛重视的原因之一就是EJB。它们提供了一个框架来开发和实施分散式商务逻辑,由此很显着地简化了具有可伸缩性和高度複杂的企业级套用的开发。EJB规范定义了EJB组件在何时以及如何与它们的容器进行互动作用。容器负责提供公用的服务,例如目录服务、事务管理、安全性、资源缓冲池以及容错性。
EJB规范定义了3中基本的BEAN类型
STATELESS SESSION BEANS: 提供某种单一的服务,不维持任何状态,在伺服器故障发生时无法继续存在,生命期相对较短。例如,一个STATELESS SESSION BEAN可能被用于执行温度转换计算。
STATEFUL SESSION BEAN: 提供了与客户端的会话互动,可以存储状态从而代表一个客户。典型例子是购物车。STATEFUL SESSION BEAN在伺服器故障时无法继续生存,生命期相对较短。每一个实例只用于一个单个的执行绪
ENTITY BEANS: 提供了一致性数据的表示-- 通常存放在资料库中 -- 在伺服器故障发生后能继续存在。多用户情况下可以使用EJB来表示相同的数据。ENTITY EJB的一个典型例子是客户的帐号信息。
儘管有以上的区别,所有的EJB还是有许多的共同之处
它们都处理HOME INTERFACE。它定义了一个客户端是如何创建与消亡EJB的。
可以在BEAN中对定义了客户端方法的远程接口进行调用;
BEAN类则执行了主要的商务逻辑描述
EJB的开发已经超出了本文的範围。,如果一个EJB已经被开发了或者从第三方进行了购买,它就必须在套用伺服器中进行发布。WEBLOGIC SERVER 5.1带有一个EJB DEPLOYER TOOL来协助处理EJB的发布。当你使用EJB DEPLOYER TOOL的时候,你要定义客户端所用的JNDI名字来定位EJB。DEPLOYER TOOL将生成WRAPPER类来处理和容器的通信以及在一个JAR档案中把被请求的JAVA类绑定在一起。一旦EJB被发布,客户端就可以使用它的JNDI名字来定位EJB。
,它必须得到一个到HOME接口的REFERENCE。
然后,客户端可以使用该接口,调用一个 CREATE() 方法来得到伺服器上运行的某个BEAN实例的句柄;
,客户端可以使用该句柄在BEAN中调用方法。
了解 EJB后,让我们再来看JSP。
JAVA SERVER PAGES (JSPS)
我们中间可能已经有许多人已经熟悉MICROSOFT的ACTIVE SERVER PAGES (ASP)技术了。JSP和ASP相对应的,但更具有平台对立性。他们被设计用以帮助WEB内容开发人员创建动态网页,并且只需要相对较少的代码。即使WEB设计师不懂得如何编程也可以使用JSP,因为JSP套用是很方便的。JSP页面由HTML(标準通用标记语言下的一个套用)代码和嵌入其中的JAVA代码所组成。伺服器在页面被客户端所请求以后对这些JAVA代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。
下面我们来看一个JSP的简单实例。它只显示了伺服器的当前日期和时间。虽然,对语法的具体解释已经超出了本文的範围,但我们还是可以很直观地看到,JAVA代码被放在<%和%>;的中间,而JAVA的表达式则放在<%=和%>;之间。
<html><head><title>SampleJSPPage</title></head><body><h1>DateJSPsample</h1><%response.setHeader("Refresh",5);%>Thecurrentdateis<%=newDate()%>.</body></html>
您可能有时候听说过JHTML。这是JSP以前的一种较老的标準。WEBLOGIC伺服器既可支持JSP,又可支持JHTML。
请注意,在预设状况下,JSP在WEBLOGIC伺服器中并没有处于有效状态。要使之有效,你可以编辑WEBLOGIC.PROPERTIES档案。如果WEB伺服器还没有处于有效状态,则要先使之有效。SERVLET的情况和JSP是一样的。
下面是JAVA SERVLETS
JAVA SERVLETS
SERVLET提供的功能大多与JSP类似,不过实现的方式不同。JSP通常是大多数HTML代码中嵌入少量的JAVA代码,而SERVLETS全部由JAVA写成并且生成HTML。
SERVLET是一种小型的JAVA程式,它扩展了WEB伺服器的功能。作为一种伺服器端的套用,当被请求时开始执行,这和CGI PERL脚本很相似。SERVLETS和CGI脚本的一个很大的区别是每一个CGI在开始的时候都要求开始一个新的进程 -- 而SERVLETS是在SERVLET引擎中以分离的执行绪来运行的。SERVLETS在可伸缩性上提供了很好的改进。在开发SERVLETS的时候,您常常需要扩展JAVA X.SERVLET.HTTP.HTTPSERVLET 类,并且OVERRIDE一些它的方法,其中包括
SERVICE(): 作为DISPATCHER来实现命令-定义方法
DOGET(): 处理客户端的HTTP GET请求。
DOPOST(): 进行HTTP POST操作
其它的方法还包括处理不同类型的HTTP请求-- 可以参考HTTPSERVLET API文档。
以上描述的是标準J2EE SERVLET API的各种方法。WEBLOGIC伺服器提供了一个该API完整的实现途径。一旦你开发了一个SERVLET,你就可以在 WEBLOGIC.PROPERTIES 中加以注册并由此可以在WEBLOGIC伺服器中对它进行配置。通过JAVA SERVLETS,我们已经到达了J2EE主要技术的末尾了。但J2EE所提供的并不止于这些。
下面的段落中我们将简要地看一下现存的一些技术,包括RMI,JAVA IDL和CORBA,JTA,以及XML(标準通用标记语言的子集),等等。
REMOTE METHOD INVOCATION (RMI)
正如其名字所表示的那样,RMI协定是在远程对象上调用一些方法。它使用了连续序列方式在客户端和伺服器端传递数据。RMI是一种被EJB使用的更下层的协定。
JAVA IDL/CORBA
在JAVA IDL的支持下,开发人员可以将JAVA和CORBA集成在一起。他们可以创建JAVA对象并使之可在CORBA ORB中展开,或者他们还可以创建JAVA类并作为和其它ORB一起展开的CORBA对象的客户。后一种方法提供了一种途径,通过它JAVA可以被用于将你的新的应 用和LEGACY系统相集成。
JAVA TRANSACTION ARCHITECTURE (JTA)/JAVA TRANSACTION SERVICE (JTS)
JTA定义了一种标準的API,套用系统由此可以存取各种事务监控。
JTS是CORBA OTS事务监控的基本实现。JTS规定了事务管理器的实现方式。该事务管理器是在高层支持JAVA TRANSACTION API (JTA)规范,并且在较底层实现OMG OTS SPECIFICATION的JAVA映像。JTS事务管理器为套用伺服器、资源管理器、独立的套用以及通信资源管理器提供了事务服务。
JAVA MAIL AND JAVA BEANS ACTIVATION FRAMEWORK
JAVA MAIL是用于存取邮件伺服器的API,它提供了一套邮件伺服器的抽象类。不仅支持SMTP伺服器,也支持IMAP伺服器JAVA MAIL利用JAVA BEANS ACTIVATION FRAMEWORK (JAF)来处理MIME-编码的邮件附属档案。MIME的位元组流可以被转换成JAVA对象,或者转换自JAVA对象。由此大多数套用都可以不需要直接使用JAF。
JAVA MESSAGING SERVICE (JMS)
JMS是用于和面向讯息的中间件相互通信的应用程式接口(API)。它既支持点对点的域,又支持发布/订阅(PUBLISH/SUBSCRIBE)类型的域,并且提供对下列类型的支持经认可的讯息传递、事务型讯息的传递、一致性讯息和具有持久性的订阅者支持。JMS还提供了另一种方式来对您的套用与LEGACY BACKEND系统相集成。
XML(标準通用标记语言的子集)
XML是一种可以用来定义其它标记语言的语言。它被用来在不同的商务过程中共享数据。XML的发展和JAVA是相互独立的,,它和JAVA具有的相同目标正是平台独立性。通过将JAVA和XML的组合,您可以得到一个完美的具有平台独立性的解决方案。目前正有许多不同的公司在为JAVA和XML的组合而努力。如果要了解更多的这方面的信息,可以访问SUN的JAVA-XML页面,或者IBM DEVELOPERWORKS的XML ZONE。
在本文中,我们介绍了建立在J2EE上的分散式套用结构,并且描述了WEBLOGIC伺服器对J2EE的各种支持。,我们所揭示的仅仅是冰山之一角而已,要以一篇数千字的文章来展示J2EE潜在的对您的企业级套用的影响可是很不公平的。
我们已经关注了在您开始用J2EE进行工作时最有可能遇到的各类技术JDBC,JNDI,EJB,JSP和SERVLET。我们也为您提供了一些尚未常见的J2EE技术的背景知识。不管您是一名开发人员,商务套用分析师,或者项目经理,都应该对J2EE和WEBLOGIC伺服器所能提供给我们,给我们的企业以及我们的企业级套用所带来的意义有一个更好的认识。
J2EE 带动了Java在企业级的发展,但随着一些轻量级组件的出现,J2EE的臃肿和开发难度高的缺点越来越引起了许多人的注意,EJB2.0也被许多人称为累赘。随着Spring,Hibernate的不断完善和发展,EJB3.0齣现了,成为了未来Java 企业级开发的新的方向。
使用元数据,注释代替传统的配置档案成为了新的热点。JPA更是代替了传统的CMP作为了更加便捷的持久化的方案。
控制策略
J2EE事务并发访问主要可以分为两类,分别是同一个系统事务和跨事务访问的并发访问控制,其中同一个系统事务可以採取乐观锁以及悲观锁策略,而跨多个系统事务时则需要乐观离线锁和悲观离线锁。
乐观锁
乐观锁是在同一个资料库事务中我们常採取的策略,因为它能使得我们的系统保持高的性能的情况下,提供很好的并发访问控制。乐观锁,顾名思义就是保持一种乐观的态度,我们认为系统中的事务并发更新不会很频繁,即使冲突了也没事,大不了重新再来一次。它的基本思想就是每次提交一个事务更新时,我们想看看要修改的东西从上次读取以后有没有被其它事务修改过,如果修改过,那幺更新就会失败。
因为乐观锁其实并不会锁定任何记录,所以资料库的事务隔离级别设定为读取已提交或者更低的隔离界别,那幺是不能避免不可重複读问题的(因为此时读事务不会阻塞其它事务),所以採用乐观锁的时候,系统应该要容许不可重複读问题的出现。
一般可以採用以下三种方法
版本(Version)栏位在我们的实体中增加一个版本控制栏位,每次事务更新后就将版本栏位的值加1.
时间戳(timestamps)採取这种策略后,当每次要提交更新的时候就会将系统当前时间和实体载入时的时间进行比较,如果不一致,那幺就报告乐观锁失败,从而回滚事务或者重新尝试提交。採用时间戳有一些不足,比如在集群环境下,每个节点的时间同步也许会成问题,并且如果并发事务间隔时间小于当前平台最小的时钟单位,那幺就会发生覆盖前一个事务结果的问题。一般採用版本栏位比较好。
基于所有属性进行检测採用这种策略的时候,需要比较每个栏位在读取以后有没有被修改过,所以这种策略实现起来比较麻烦,要求对每个属性都进行比较,如果採用hibernate的话,因为Hibernate在一级快取中可以进行髒检测,那幺可以判断哪些栏位被修改过,从而动态的生成sql语句进行更新。
在JDBC和Hibernate中使用乐观锁
JDBC中使用乐观锁如果我们採用JDBC来实现持久层的话,那幺就可以採用以上将的三种支持乐观锁的策略,在实体中增加一个version栏位或者一个Date栏位,也可以採用基于所有属性的策略,下面就採用version栏位来做一演示
假如系统中有一个Account的实体类,我们在Account中多加一个version栏位,那幺我们JDBC Sql语句将如下写
Select a.version....from Account as a where (where condition..)
Update Account set version = version+1.....(another field) where version =?...(another contidition)
可以通过更新结果的行数来进行判断,如果更新结果的行数为0,那幺说明实体从载入以来已经被其它事务更改了,所以就抛出自定义的乐观锁定异常(或者也可以採用Spring封装的异常体系)。具体实例如下
.......introwsUpdated=statement.executeUpdate(sql);If(rowsUpdated==0){throwsnewOptimisticLockingFailureException();}........
在使用JDBC API的情况下,需要在每个update语句中,都要进行版本栏位的更新以及判断,如果稍不小心就会出现版本栏位没有更新的问题,相反当前的 ORM框架却为我们做好了一切,需要做的就是在每个实体中都增加version或者是Date栏位。
Hibernate中使用乐观锁如果採用Hibernate做为持久层的框架,那幺实现乐观锁将变得非常容易,因为框架会帮我们生成相应的sql语句,不仅减少了开发人员的负担,而且不容易出错。下面同样採用version栏位的方式来一下
同样假如系统中有一个Account的实体类,我们在Account中多加一个version栏位,
publicclassAccount{Longid;.......@Version//也可以採用XML档案进行配置Intversion.......}
提交事务时,hibernate内部会生成相应的SQL语句将版本栏位加1,并且进行相应的版本检测,如果检测到并发乐观锁定异常,那幺就抛出StaleObjectStateException.
悲观锁
所谓悲观锁,顾名思义就是採用一种悲观的态度来对待事务并发问题,系统中的并发更新会非常频繁,并且事务失败了以后重来的开销很大,这样就需要採用真正意义上的锁来进行实现。悲观锁的基本思想就是每次一个事务读取某一条记录后,就会把这条记录锁住,这样其它的事务要想更新,必须等以前的事务提交或者回滚解除锁。
还是需要明确一个问题,假如资料库事务的隔离级别设定为读取已提交或者更低,那幺通过悲观锁,控制了不可重複读的问题,不能避免幻影读的问题(因为要想避免我们就需要设定资料库隔离级别为Serializable,而一般情况下会採取读取已提交或者更低隔离级别,并配合乐观或者悲观锁来实现并发控制,所以幻影读问题是不能避免的,如果想避免幻影读问题,那幺只能依靠资料库的serializable隔离级别(幸运的是幻影读问题一般情况下不严重)。
下面就分别以JDBC和Hibernate来一下
JDBC中使用悲观锁在JDBC中使用悲观锁,需要使用select for update语句,假如我们系统中有一个Account的类,我们可以採用如下的方式来进行
Select from Account where ...(where condition).. for update.
当使用了for update语句后,每次在读取或者载入一条记录的时候,都会锁住被载入的记录,那幺当其他事务如果要更新或者是载入此条记录就会因为不能获得锁而阻塞,这样就避免了不可重複读以及髒读的问题,其他事务还是可以插入和删除记录,这样也许同一个事务中的两次读取会得到不同的结果集,这不是悲观锁所造成的问题,这是资料库隔离级别所造成的问题。
还需要注意的一点就是每个冲突的事务中,必须使用select for update 语句来进行资料库的访问,如果一些事务没有使用select for update语句,那幺就会很容易造成错误,这也是採用JDBC进行悲观控制的缺点。
Hibernate中使用悲观锁相比于JDBC使用悲观锁来说,在Hibernate中使用悲观锁将会容易很多,因为Hibernate有API让我们来调用,从而避免直接写SQL语句。下面就Hibernate使用悲观锁做一
先要明确一下Hibernate中支持悲观锁的两种模式LockMode.UPGRADE以LockMode.UPGRADE_NO_WAIT.(PS在JPA中,对应的锁模式是LockModeType.Read,这与Hibernate是不一样的呵呵)
假如系统中有一个Account的类,那幺具体的操作可以像这样
......session.lock(account,LockMode.UPGRADE);......
或者也可以採用如下方式来载入对象
session.get(Account.class,identity,LockMode.UPGRADE).
这样以来当载入对象时,hibernate内部会生成相应的select for update语句来载入对象,从而锁定对应的记录,避免其它事务并发更新。
发展状况
目前,Java 2平台有3个版本,它们是适用于小型设备和智慧卡的Java 2平台Micro版(Java 2 Platform Micro Edition,J2ME)、适用于桌面系统的Java 2平台标準版(Java 2 Platform Standard Edition,J2SE)、适用于创建伺服器应用程式和服务的Java 2平台企业版(Java 2 Platform Enterprise Edition,J2EE)。J2EE是一种利用Java 2平台来简化企业解决方案的开发、部署和管理相关的複杂问题的体系结构。J2EE技术的基础就是核心Java平台或Java 2平台的标準版,J2EE不仅巩固了标準版中的许多优点,例如"编写一次、随处运行"的特性、方便存取资料库的JDBC API、CORBA技术以及能够在Internet套用中保护数据的安全模式等等,还提供了对 EJB(Enterprise JavaBeans)、Java Servlets API、JSP(Java Server Pages)以及XML(标準通用标记语言的子集)技术的全面支持。其最终目的就是成为一个能够使企业开发者大幅缩短投放市场时间的体系结构。
J2EE体系结构提供中间层集成框架用来满足无需太多费用而又需要高可用性、高可靠性以及可扩展性的套用的需求。通过提供统一的开发平台,J2EE降低了开发多层套用的费用和複杂性,提供对现有应用程式集成强有力支持,完全支持Enterprise JavaBeans,有良好的嚮导支持打包和部署套用,添加目录支持,增强了安全机制,提高了性能。
J2EE是由SUN公司开发的一套企业级套用规范。2009年04月20日,甲骨文74亿美元收购Sun。取得java的着作权。2011年7月,甲骨文公司发布java7的正式版。支持J2EE的套用伺服器有IBM WebSphere Application Server,Oracle Weblogic SERVER,Jboss,SUN GlassFish,东方通 TongWeb等。
发展趋势
在旧金山举行的2011年JavaOne大会上,甲骨文公司展示了其推动Java 平台企业版(Java EE)发展的最新成果。
Java EE 继续大受欢迎,并有越来越多的开发人员採用,包括Oracle GlassFish Server在内的Java EE组件获得了4000万次下载。
自2009年12月推出以来,6个主要IT厂商已经推出了经过认证、开源和商业实施的Java EE 6,使其成为迄今为止最迅速获得採用的平台产品。
作为下一代Java EE, Java EE 7进展顺利,其中,有超过20个的不同参与企业和数百名工程师通过Java 社区(JCP)对10个活跃的Java规范要求(JSRs)进行了开发处理。
Java EE 7 JSRs 包括Java EE 7 平台, Java Persistence API 2.1, JAX-RS 2.0: 用于RESTful网路服务的 Java API, Servlet 3.1, 表达语言 3.0, Java 信息服务 2.0, JavaServer Faces 2.2, Enterprise JavaBeans 3.2, 面向Java EE 1.1的Contexts and Dependency Injection , Bean Validation 1.1.等。
Java EE 7专家组也在寻求把其他JSRs加入到Java EE 7的可能性,这些JSRs包括JCache 1.0 – Java Temporary Caching API, Concurrency Utilities 1.0, Java 状态管理 1.0 和Java Identity API 1.0。
Java EE 7旨在进一步增强Java EE平台的云环境。,基于Java EE-7的套用和产品将能够在私有云和公有云中更方便地操作,并通过支持多用户租用和弹性使用(如平行扩展)等功能来实现功能即服务。
作为Java EE的参考实施,GlassFish伺服器不仅仅是全面的Java EE 6实施,(开源版是GlassFish 伺服器开源版,商业版是Oracle GlassFish伺服器),还为即将推出的Java EE 7提供了坚实的基础。
Oracle GlassFish伺服器完善了Oracle WebLogic 伺服器 11g,后者是一款专门为运行Oracle 融合中间件11g的广泛产品组合以及可内部部署和云部署的大规模企业套用而设计的伺服器。
甲骨文在2011 年JavaOne大会的136个联合研讨会、BOF和动手实验室,以及JavaOne展览馆中对Java EE及相关技术进行了展示。
组合框架
从整体上讲,J2EE是使用Java技术开发企业级套用的一种事实上的工业标準(Sun公司出于其自身利益的考虑,至今没有将Java及其相关技术纳入标準化组织的体系),它是Java技术不断适应和促进企业级套用过程中的产物。目前,Java平台有三个版本适用于小型设备和智慧卡的J2ME(Java 2 Platform Micro Edition)、适用于桌面系统的J2SE和适用于企业级套用的J2EE。Sun推出J2EE的目的是为了克服传统Client/Server模式的弊病,迎合Browser/Server架构的潮流,为套用Java技术开发伺服器端套用提供一个平台独立的、可移植的、多用户的、安全的和基于标準的企业级平台,从而简化企业套用的开发、管理和部署。J2EE是一个标準,而不是一个现成的产品。各个平台开发商按照J2EE规范分别开发了不同的J2EE套用伺服器,J2EE套用伺服器是J2EE企业级套用的部署平台。由于它们都遵循了J2EE规范,,使用J2EE技术开发的企业级套用可以部署在各种J2EE套用伺服器上。