前面的几篇文章我们已经介绍了中间件的相关知识了,这篇我们文章我们了解下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技术进行了比较。

中间件学习——J2EE中间件四步曲相关推荐

  1. java中间件学习1-java中间件的定义

    1.java中间件的定义 在java web开发的演进与进化中,我们对于消息系统,数据库,服务化接口的抽象等,涉及数据分离的过程中,在分离过程中,就会涉及到分离后系统间,数据库间的交互.java中间件 ...

  2. 中间件静态文件服务器,从koa-static中间件学习搭建静态文件服务器

    从koa和第,.年过事工宗据指数遍互业经搞断果会-static中间件学习搭建静态抖要支圈者器说是事天开的.年后编定功口小发还应久剑文件服务器 koa-作一新求抖直微圈send Static file ...

  3. 中间件 - 学习/实践

    1.应用场景 主要用于学习互联网项目开发中的中间件技术,分类,本质,应用场景 从而更佳熟练掌握,使用,高效使用,达成目标. 2.学习/操作 1.文档阅读 Laravel - 中间件 - 学习/实践_w ...

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

    scrapy源码解析参考连接:https://www.jianshu.com/p/d492adf17312 ,直接看大佬的就行了,这里便就不多说了. 今天要学习的是:Scrapy框架中的downloa ...

  5. 什么是中间件?常见中间件有哪些?

    文章目录 中间件是什么 为什么使用中间件 常见的中间件有哪些 中间件是什么 中间件是一种独立的系统软件或服务程序,分布式应用软件借助这种软件在不同的技术之间共享资源.中间件位于客户机/ 服务器的操作系 ...

  6. Spring中间件 - 什么是中间件

    一.前言 在互联网应用开发初期,所有用于支撑系统建设的,框架结构.基础工具.业务逻辑.功能服务包括页面展示等,都是在一个系统中开发完成,最终也只是把系统和数据库部署在同一台服务器上. 但随着互联网应用 ...

  7. 后盾网lavarel视频项目---lavarel中间件(使用中间件拦截没登录的用户)

    后盾网lavarel视频项目---lavarel中间件(使用中间件拦截没登录的用户) 一.总结 一句话总结: 1.中间件中验证用户是否登录:if(!Auth::guard('admin')->c ...

  8. 自我总结(五)---(学习j2ee)

    自我完善的过程就是在不断的自我总结不断的改进. 我们这半个月来都是学习j2ee.这个知识是很重要的,一般我们出去工作都是会用到的.我们的星期六,星期天也是不上课的.所以说我相当于上了十天的j2ee了. ...

  9. Java中间件(1)--分布式系统中间件从入门到精通(五)

    上篇文章说了,当业务数据量大的时候,可以考虑业务和数据分离,当还解决不了的时候,可以考虑把数据库读写分离,缓存,还可以考虑把表垂直拆分,水平拆分. 大型网站架构(2)--分布式系统&中间件从入 ...

  10. PHP中间件 middleware,middleware 中间件详解

    如果感觉这篇文章有用请点个赞,让我知道自己的努力不白费!!! 中间件是请求必经之处,所以此处能对请求的数据做一系列处理,相当于过滤器.例如跨域请求,验证会员是否登录跳转至登录页,前后端分离数据类型不一 ...

最新文章

  1. LiveVideoStack线上分享第四季(八):实时远程医学影像服务质量保障与网络优化...
  2. 【RS】Amazon.com recommendations: item-to-item collaborative filtering - 亚马逊推荐:基于物品的协同过滤...
  3. 分布式技术一周技术动态 2016.07.10
  4. shell脚本while read line的使用
  5. 【技术干货+限时活动】openstack原理及在华为云中的应用
  6. 网络(6)-TCP/IP对拥塞控制、滑动窗口如何实现可靠性?
  7. python两个等号和一个等号_Python-一个变量等于另一个变量
  8. Linux c实现一个tcp文件服务器和客户端
  9. # heapsort
  10. Verilog初级教程(13)Verilog中的块语句
  11. 测井曲线wis文件格式转换为ASCII文本格式小软件的开发(C与Python结合开发)
  12. 爬取今日头条新闻,并导入execle中(主要用了selenium)
  13. 2、恩智浦-车规级-MCU :S32K11X GPIO实验
  14. 倍福TwinCAT(贝福Beckhoff)应用教程12.3 TwinCAT控制松下伺服 NC进阶
  15. 视频的传输方式【转】
  16. python3两个三阶矩阵相乘_矩阵相乘的实现-python
  17. fastadmin中ajax传参
  18. 聊下如何设计知识中台?(附代码)
  19. 最简单小米设备怎么不root激活xposed框架
  20. oracle client 安装及卸载

热门文章

  1. 软件工程毕设(五)·外文翻译
  2. N1盒子使用T1遥控和电视一起开关机以及按键设置
  3. 轴承后缀ce和ca_轴承cc和ca与cde4有什么区别
  4. OBV指标交易策略(累积能量潮与移动能量潮,成交量多空比率净额及相关应用原则)
  5. Vue开发实例(04)之更换项目入口
  6. TX2(linux系统、Ubuntu系统)输入法不显示拼音候选框、下拉框
  7. 2022道路运输企业安全生产管理人员复训题库及答案
  8. python答辩毕设ppt_如何制作优秀的毕业论文答辩 PPT?
  9. 详解反向传播神经网络 (Back Propagation Neural Network, BPNN)
  10. 群晖J3455安装DS3617xs 6.2.3折腾教程