热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

系统架构设计笔记(79)——J2EE

J2EE是针对WebService、业务对象、数据访问和消息报传送的一组规范。这组应用编程接口确定了Web应用与驻留它们的服务器之间的通信方式。J2EE

J2EE 是针对 Web Service 、 业务对象 、 数据访问和消息报传送的一组规范。这组应用编程接口确定了 Web 应用与驻留它们的服务器之间的通信方式。

J2EE 注重两件事,一是建立标准,使 Web 应用的部署与服务器无关;二是使服务器能控制构件的生命周期和其他资源,以便能够处理扩展 、 并发 、 事务处理管理和安全性问题。

J2EE 规范定义了以下几种构件:应用客户端构件 、 EJB构件 、 Servlets和JSP 、 Applet构件。 J2EE 采用的是多层分布式应用模型,意味着应用逻辑将根据功能分成几个部分,用户可以在相同或不同的服务器上安装不同应用构件组成的 J2EE 应用。这些层次可以参见图 1。

系统架构设计笔记(79)—— J2EE

1 表示层

J2EE 客户端可以基于 Web ,也可以基于 Java 。 在 HTML 、 Java script 、 XML 等技术的帮助下, Web 浏览器可以支持强大 、 快速的用户界面。实际上,如果 HTML 足以捕获和显示应用所需的信息,则 HTML 为首选;如果 HTML 不足以达到此目的,则应该由客户端执行必要的捕获和操作。无论是 Applet 还是独立的 Java 程序,都可提供更丰富的图形用户界面。

Applet 还可以与中层通信,从而进一步加强程序控制和系统灵活性。分布式企业应用可以同时包括多种客户端,并且这些客户端都可以访问相同的业务逻辑。如图 2所示:当客户端是 HTML 时, JSP/Servlet 组合将成为能实现业务目标的真正客户端。当客户端是 Java 程序或基于 COM 程序时,它可以直接访问业务逻辑。

系统架构设计笔记(79)—— J2EE

2 应用服务层

一般情况下,应用服务层包含表示层请求的表示逻辑和业务逻辑。表示层由显示 HTML 页面的 JSP 页面和 Servlets 实现。业务逻辑通过 RMI 对象和 EJB 实现。 EJB 依靠容器来实现事务处理 、 生命周期和状态管理 、 资源池 、 安全等问题,容器是 EJB 运行的环境。

2.1 Servlet

Java Servlet s 是指可以扩展 Web 服务器功能的程序 。 Servlet 从客户端接受请求,动态生成响应,然后将包含 HTML 或 XML 文档的请求发送给客户端 。 Servlet 类似于 CGI (公共网关接口),但 Servlet 使用 Java 类和流,更易于编写;由于 Servlet 可编译为 Java 字节码,在运行时, Servlet 例程驻留在内存中,每一个用户请求都生成一条新线程,故而它们的执行速度也更快。

2.2 JSP

JSP 页面是基于文本的 Servlet 开发方式。 JSP 页面具有 Servlet 的所有优点,如果与 Java Beans 类结合在一起,可以容易地将内容和显示逻辑分开。这使得无须了解 Java 代码就能更新页面的外观,更新 Java Beans 类的人也无须深入了解 Web 页面的设计。相对 CGI 而言,由于 CGI 依赖于平台,消耗资源更多,而且程序不能容易地访问参数数据等缺点,故而 JSP 页面和 Servlet 都比 CGI 应用广泛。

用户可以使用带 Java Beans 类的 JSP 页面定义 Web 模板,以便建立由外观相似的页面组成的 Web 站点,而 Java Beans 类负责组织数据。用户还可以借助标记和脚本将内容与应用逻辑捆绑在一起,或是嵌入一些 Java 小应用程序来实现一些简单的 Web 应用。

2.3 JMS

JMS 是支持 Java 程序之间信息交换的 J2EE 机制。这也是 Java 支持异步通信的方法 —— 发送者和接收者无须相互了解,因此可以独立操作。

JMS 支持两种消息传播模式:

点到点( pointtopoint )。基于消息队列,消息产生者将消息发送到队列中。消息消费者可以将自身与队列连接,以倾听消息。当消息到达队列时,客户可以从队列中取走,并给出响应。消息只能发送到一个队列,只能由一个消费者使用。消费者可以过滤消息,以便获得希望获得的消息。

出版和订阅( publish/subscribe )。消息生产者将消息发送到一个话题( topic ),注册到此话题的消费者都能接收到这些消息。这种情况下,许多消费者都能接收到同样的消息。

2.4 JNDI

由于 J2EE 应用的构件可以独立运行,而且是在不同的设备上运行,因此客户端和应用服务器层代码必须以某种方式查找和参考其他代码和资源。客户端和应用代码使用 JNDI ( Java Namingand Directory Interface , Java 命名和目录接口)查找用户定义对象(如 EJB )和环境实体( Environment Entities )。在 JDBC2.0 中,数据源可以绑定到 JNDI 上,并允许应用程序访问。

2.5 事务处理

J2EE 事务处理模型可以在部署过程中定义组成一个事务处理的方法之间的联系,以便事务处理中的所有方法可以作为一个整体存在。如果用户希望完成这一任务,因为事务处理是一系列步骤,要么全部执行成功,要么全部回滚。例如, EJB 中可能有一系列方法,其作用是将资金从一个账户转到另一个账户,方法是借记第一个账户和贷记第二个账户。用户可能希望将全部操作作为一个整体,这样,如果借记之后,贷记之前出现故障,借记将滚回。

事务处理的属性在应用构件的集成过程中确定。它可以将各种方法组合成应用构件间的事务处理,即用户可以在 J2EE 应用中方便地重新分配应用构件的事务处理属性,无须修改代码和重新编译。

J2EE 事务处理 API ( JTA )和 Java 事务处理服务( JTS )形成 J2EE 中事务处理支持的基础,而且更适合 EJB 和JDBC2.0。 JTS 是低级事务处理管理 API ,主要作用是将 Java 映射到对象管理组( OMG )的对象事务处理服务。 JTA 是高级 API ,包括两个部分:

  1. 事务处理接口。该接口允许事务处理定界,通过分布式构件由进行全局事务处理登记来完成工作。这种方法可以令多组操作组成一个事务处理 。

  2. XA 资源接口。基于能处理分布式事务处理的 X/Open/ XA 接口,有时也称为两步提交事务处理,需要多种资源之间的协调,如数据库或序列。分布式事务处理由两步提交协议协调,可跨越用 XA 兼容的 JDBC 驱动程序访问的多个数据库,如针对Oracle/ XA 的 BEAWeb Logic Driver 等 。

EJB 规范定义了 Bean 管理的事务处理和 Container 管理的事务处理。当 EJB 用 Container 管理的事务处理部署时,应用服务器将自动协调事务处理。如果 EJB 由 Bean 管理事务处理部署, EJB 参数必须提供事务处理代码。基于 JMS 或 JDBC API的应用代码可以启动事务处理,或参与先前启动的事务处理。一个事务处理联系与执行应用的应用服务器线程相关,所有事务处理操作都在参与当前事务处理的线程上执行。多数情况下,用户无须担心用 JTA 编写明确事务处理的问题,因为此项工作由 JDBC 完成, EJB API由 Container 处理,并由应用部署说明符配置。这样,用户就可以将精力集中在事务处理设计而非实施上。


系统架构设计笔记(79)—— J2EE

推荐阅读
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
  • 本文详细介绍了JSP的三大指令:page、include和taglib,重点探讨了静态包含与动态包含的区别及其应用场景,并解释了如何使用taglib指令引入第三方标签库。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 本文详细介绍了如何在Kendo UI for jQuery的数据管理组件中,将行标题字段呈现为锚点(即可点击链接),帮助开发人员更高效地实现这一功能。通过具体的代码示例和解释,即使是新手也能轻松掌握。 ... [详细]
  • 深入理解ExtJS:从入门到精通
    本文详细介绍了ExtJS的功能及其在大型企业前端开发中的应用。通过实例和详细的文件结构解析,帮助初学者快速掌握ExtJS的核心概念,并提供实用技巧和最佳实践。 ... [详细]
  • 本文详细介绍了如何在Android 4.4及以上版本中配置WebView以实现内容的自动高度调整和屏幕适配,确保中文显示正常,并提供代码示例。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • 主板IO用W83627THG,用VC如何取得CPU温度,系统温度,CPU风扇转速,VBat的电压. ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
author-avatar
好人___夏洁
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有