热门标签 | 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

推荐阅读
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
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社区 版权所有