《2023年【精品】J2EE系统设计方案.pdf》由会员分享,可在线阅读,更多相关《2023年【精品】J2EE系统设计方案.pdf(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 J 2 EE 系 统 设 计 方 案 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除2 J2EE 系统技术方案 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或
2、者删除3 J2EE 系统技术方案.2 一、技术平台.3 1.J2EE 的概念.4 2.J2EE 的优势.5 3.J2EE 相关核心技术.6 4.轻量级 J2EE 架构.9 二、应用部署架构.10 1.服务器操作系统.10 2.Web 服务器架构.10 3.系统数据库.11 三、开发关键技术.11 1.软件版本与工具.12 2.主要技术方案.13 3.业务逻辑层.14 4.数据持久层.15 5.域对象层.16 6.WEB 层.16 7.任务调度.17 8.Ajax 技术.17 四、系统缓存.18 1.一般缓存策略.18 2.Hibernate 二级缓存.18 3.JSP 页面缓存.19 五、软件
3、成本比较.19 一、技术平台 J2EE(Java 2 Enterprise Edition)是建立在 Java 2 平台上的企业级应用的解决方案。J2EE 技术的基础便是 Java 2 平台,不但有 J2SE 平台的所有功能,同时还提供了对 EJB,Servlet,JSP,XML 等技术的全面支持,其最终目标是成 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的
4、体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除4 为一个支持企业级应用开发的体系结构,简化企业解决方案的开发,部署和管理等复杂问题。事实上,J2EE 已经成为企业级开发的工业标准和首选平台。市场上可以看到很多实现了 J2EE 的产品,如 BEA WebLogic,IBM WebSphere 以及开源的 JBoss 等等。J2EE 并非一个产品,而是一系列的标准,它是由 sun 公司提出的,符合这个标准的产品叫 实现。1.J2EE 的概念 目前,Java 2 平台有 3 个版本,它们是适用于小型设备和智
5、能卡的 Java 2 平台 Micro 版(Java 2 Platform Micro Edition,J2ME)、适用于桌面系统的 Java 2平台标准版(Java 2 Platform Standard Edition,J2SE)、适用于创建服务器应用程序和服务的 Java2 平台企业版(Java 2 Platform Enterprise Edition,J2EE)。J2EE 是一种利用 Java 2 平台来简化企业解决方案的开发、部署和管理相关的复杂问题的体系结构。J2EE 技术的基础就是核心 Java 平台或 Java 2 平台的标准版,J2EE 不仅巩固了标准版中的许多优点,例如
6、编写一次、随处运行 的特性、方便存取数据库的 JDBC API、CORBA 技术以及能够在 Internet 应用中保护数据的安全模式等等,同时还提供了对 EJB(Enterprise JavaBeans)、Java Servlets API、JSP(Java Server Pages)以及 XML 技术的全面支持。其最终目的就是成为一个能够使企业开发者大幅缩短投放市场时间的体系结构。J2EE 体系结构提供中间层集成框架用来满足无需太多费用而又需要高可用性、高可靠性以及可扩展性的应用的需求。通过提供统一的开发平台,J2EE 降平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服
7、务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除5 低了开发多层应用的费用和复杂性,同时提供对现有应用程序集成强有力支持,完全支持 Enterprise JavaBeans,有良好的向导支持打包和部署应用,添加目录支持,增强了安全机制,提高了性能。2.J2EE 的优势 J2EE 为搭建具有可
8、伸缩性、灵活性、易维护性的商务系统提供了良好的机制。这之所以成为可能是因为 J2EE 拥有广泛的业界支持和一些重要的 企业计算 领域供应商的参与。每一个供应商都对现有的客户提供了不用废弃已有投资,进入可移植的 J2EE 领域的升级途径。由于基于 J2EE 平台的产品几乎能够在任何操作系统和硬件配置上运行,现有的操作系统和硬件也能被保留使用。高效的开发:J2EE 允许公司把一些通用的、很繁琐的服务端任务交给中间件供应商去完成。这样开发人员可以集中精力在如何创建商业逻辑上,相应地缩短了开发时间。高级中间件供应商提供以下这些复杂的中间件服务。状态管理服务:让开发人员写更少的代码,不用关心如何管理状态
9、,这样能够更快地完成程序开发。持续性服务:让开发人员不用对数据访问逻辑进行编码就能编写应用程序,能生成更轻巧,与数据库无关的应用程序,这种应用程序更易于开发与维护。平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除6 分布式共
10、享数据对象 CACHE 服务-让开发人员编制高性能的系统,极大提高整体部署的伸缩性。支持异构环境:J2EE 能够开发部署在异构环境中的可移植程序。基于 J2EE的应用程序不依赖任何特定操作系统、中间件、硬件。因此设计合理的基于 J2EE 的程序只需开发一次就可部署到各种平台。这在典型的异构企业计算环境中是十分关键的。J2EE 标准也允许客户订购与 J2EE 兼容的第三方的现成的组件,把他们部署到异构环境中,节省了由自己制订整个方案所需的费用。可伸缩性:企业必须要选择一种服务器端平台,这种平台应能提供极佳的可伸缩性去满足那些在他们系统上进行商业运作的大批新客户。基于 J2EE 平台的应用程序可被
11、部署到各种操作系统上。例如可被部署到高端 UNIX 与大型机系统,这种系统单机可支持 64 至 256 个处理器。(这是 NT 服务器所望尘莫及的)J2EE 领域的供应商提供了更为广泛的负载平衡策略。能消除系统中的瓶颈,允许多台服务器集成部署。这种部署可达数千个处理器,实现可高度伸缩的系统,满足未来商业应用的需要。稳定的可用性:J2EE 部署到可靠的操作环境中,支持长期的可用性。一些J2EE 部署在 WINDOWS 环境中,客户也可选择健壮性能更好的操作系统如Linux,Sun Solaris、IBM OS/390。3.J2EE 相关核心技术 平台的概念的优势相关核心技术轻量级架构二应用部署架
12、构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除7 J2EE 的各种组件、服务和 API,进行更加详细的阐述,在开发不同类型的企业级应用时,根据各自需求和目标的不同,应当如何灵活使用并组合不同的组件和服务。Servlet Servlet 是 Java 平台上的 CGI 技术
13、。Servlet 在服务器端运行,动态地生成Web 页面。与传统的 CGI 和许多其它类似 CGI 的技术相比,Java Servlet 具有更高的效率并更容易使用。对于 Servlet,重复的请求不会导致同一程序的多次转载,它是依靠线程的方式来支持并发访问的。JSP JSP(Java Server Page)是一种实现普通静态 HTML 和动态页面输出混合编码的技术。从这一点来看,非常类似 Microsoft ASP、PHP 等技术。借助形式上的内容和外观表现的分离,Web 页面制作的任务可以比较方便地划分给页面设计 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架
14、构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除8 人员和程序员,并方便地通过 JSP 来合成。在运行时态,JSP 将会被首先转换成 Servlet,并以 Servlet 的形态编译运行,因此它的效率和功能与 Servlet 相比没有差别,一样具有很高的效率。JDBC JDBC(Java Data
15、base Connectivity,Java 数据库连接)API 是一个标准SQL(Structured Query Language,结构化查询语言)数据库访问接口,它使数据库开发人员能够用标准 Java API 编写数据库应用程序。JDBC API 主要用来连接数据库和直接调用 SQL 命令执行各种 SQL 语句。利用 JDBC API 可以执行一般的 SQL 语句、动态 SQL 语句及带 IN 和 OUT 参数的存储过程。Java 中的 JDBC相当与 Microsoft 平台中的 ODBC(Open Database Connectivity)。JMS JMS(Java Message
16、 Service,Java 消息服务)是一组 Java 应用接口,它提供创建、发送、接收、读取消息的服务。JMS API 定义了一组公共的应用程序接口和相应语法,使得 Java 应用能够和各种消息中间件进行通信,这些消息中间件包括 IBM MQ-Series、Microsoft MSMQ 及纯 Java 的 SonicMQ。通过使用 JMS API,开发人员无需掌握不同消息产品的使用方法,也可以使用统一的 JMS API来操纵各种消息中间件。通过使用 JMS,能够最大限度地提升消息应用的可移植性。JMS 既支持点对点的消息通信,也支持发布/订阅式的消息通信。JNDI 由于 J2EE 应用程序组
17、件一般分布在不同的机器上,所以需要一种机制以便于组件客户使用者查找和引用组件及资源。在 J2EE 体系中,使用 JNDI(Java Naming and Directory Interface)定位各种对象,这些对象包括 EJB、数据库驱平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者
18、删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除9 动、JDBC 数据源及消息连接等。JNDI API 为应用程序提供了一个统一的接口来完成标准的目录操作,如通过对象属性来查找和定位该对象。由于 JNDI 是独立于目录协议的,应用还可以使用 JNDI 访问各种特定的目录服务,如LDAP、NDS 和 DNS 等。4.轻量级 J2EE 架构 目前 J2EE 应用中,由于应用需求不同,架构设计上分成两种设计方式,即重量级 J2EE 架构和轻量级 J2EE 架构。银行,电信,大型企业的业务系统逻辑复杂,结点分布广泛,且普遍使用了物理上多层架构,事务要求性极高,对系统的稳定性要求也是极高的
19、,因此大多数使用重量级的 EJB 开发架构。一般的中小型应用系统,所关注的是访问速度与快速响应市场需求变化,强大的系统缓存功能,传统的大型分布式 J2EE 架构就显得不太合适。本系统的开发基于 J2EE 的轻量级多层架构,即业界比较成熟的 Struts2+Spring+Hibernate 框架:Struts2 实现 MVC 最为成熟的框架之一,在 J2EE 项目中应用广泛;Spring 可以实现对 Hibernate 的无缝链接,适用于业务处理层;在数据持久层中,采用 Hibernate 这一功能强大的 ORM 映射工具。J2EE 的三层结构在业界是指表示层(Presentation),业务逻
20、辑层(Business logic)以及基础架构层(Infrastructure)。一个最常用的扩展就是将三层体系扩展为五层体系,即表示层(Presentation)、控制/中介层(Controller/Mediator)、领域层(Domain)、数据持久层(Data Persistence)和数据源层(Data Source)。它其实是在三层架构中增加了两个中间层。控制/中介层位于表示层和领域层之间,数据持 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平
21、台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除10 久层位于领域层和基础架构层之间。而轻量级架构 Struts2+Spring+Hibernate可以实现 J2EE 多层结构,Struts2 用于表示层、控制层,Spring 用于业务处理层,而 Hibernate 用于数据持久层。二、应用部署架构 1.服务器操作系统 GSR 系统将运行在 Linux 操作系统,Linux 最大的优点在于它作为服务器操作系
22、统的强大功能,还有它的可靠的性能,稳定性与网络安全性,是大型企业和网络中心加高服务器首选的操作系统,它提供了最常用最广泛使用的诸如负载均衡,远程镜像等集成解决方案。J2EE 作为一种跨操作系统平台的应用系统平台,在 Linux 上面可以表现出非常好的性能。2.Web 服务器架构 JBoss 是一个运行 EJB 的健壮的、高质量的和性能良好的 J2EE 应用服务器。它是开放源代码的项目,遵循最新的 J2EE 规范。从 JBoss 项目开始至今,它已经从一个 EJB 容器发展成为一个基于的 J2EE 的一个 web 操作系统。具有革命性的 JMX 微内核服务作为其总线结构;面向服务的架构(Serv
23、ice-Oriented Architecture,SOA);具有统一的类装载器,从而能够实现应用的热部署和热卸载能力。平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除11 JBoss 集成了 Tomcat 做为 Web 服
24、务器,Tomcat 优点是免费,实现 J2ee 规范最好的应用服务器,可以极大地降低甲方的运营成本。Tomcat 是 Apache 的核心项目之一,也被 SUN 视作 Servlet/JSP 容器的一个重要参考实现而加以支持。因此 SUN 最新的 Servlet/JSP 规范,往往能够很快地在 Tomcat 的新版本中得到体现;Tomcat 是一个小巧精致的 web 应用服务器,配置、安装、运行、部署 web 应用都很简单;Tomcat 与开源紧密结合,开源软件的生命力,往往与其社区的状况有紧密的联系。综上所述,采用此种服务器配置方案无论从成本上还是系统性能和安全上考虑都是非常合适的。3.系统
25、数据库 中心数据库系统使用 Oracle10g,oracle 是业界各方面最好的数据库。节点数据库使用 MySQL,MySQL 是最流行的开放源码 SQL 数据库管理系统,它是由 MySQL AB 公司开发、发布并支持的。MySQL 是一种关联数据库管理系统,它是一种开放源码软件。MySQL 具有良好的扩展性,在数据访问上遇到瓶颈时,可以部署 MySQL 集群来实现负载均衡。三、开发关键技术 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有
26、功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除12 1.软件版本与工具 名称 版本号 说明 JavaSE 6.0 Java 虚拟机版本号 J2EE 1.4 J2EE 平台版本号 JSP 2.0 JSP 界面编写版本规范 JSTL 1.1 JSP 标准标签库版本 Servlet 2.4 Servlet 引擎版本规范 Struts 2.1 WEB 层 MVC 框架版本 Spring 2.0 轻量级业务逻辑层处理框架 Xfire
27、 2.0 Web Service 实现技术 Hinbernate 3.1 ORM 对象关系映射层版本 XHtml 1.1 Html 书写版本规范 CSS 2.0 Html 样式版本规范 JQuery 2.2 Ajax 框架版本号 Ext 2.0 Javascript 类库 Acige 2.0 权限控制框架 开发工具:工具名称 工具版本 说明 Eclipse 3.3 Java IDE MyEclipse 6.0 J2EE 开发工具 PowerDesigner 12 数据库设计工具 JBoss 4.2 Java 应用服务器版本号 Tomcat 6.0 开发测试服务器 Oracle 10g Mysq
28、l 5.18 数据库版本号 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除13 2.主要技术方案 系统架构图:从架构图中可以看出系统分为四层:UI 层:借助 JSP,Struts 实现 业务层:借助 Spring Fram
29、ework 进行业务组件的组装关联。数据持久层:借助 Hibernate 实现 域对象层:将所有域对象划分在一个层面 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除14 采用这样的四层架构可以达到以下效果:通过成熟的开源产
30、品实现各层,同自己编写代码实现,相比之下能缩短开发周期,且架构所用到的开源产品均有 很广泛的用户群,经受过实践的考验,质量和性能更有保障。层与层之间松散耦合,增加代码重用率。各层分工明确,这样也利于团队的明确分工。3.业务逻辑层 在实际的项目开发中,每个领域都会有自己独特的业务逻辑,正因为这样,致使项目中代码高度耦合,原本有可能被重用的代码 或功能,因为与具体的业务逻辑绑定在一块而导致很难被重用。因此我们将实现这些具体逻辑的代码抽取出来分为单独的一层,其目的是希望通过层,来降低它与系统其他部分的耦合度。现实中世界是变化的,既然该层实现的是现实中具体的业务逻辑,那该层的实现代码不可避免的会发生变
31、更。怎样让该层适应 最大的变化,做到最小的改动?通常我们在编码的时候会尽量考虑到同一业务多种实现的兼容和可扩展的能力。因此我们在 该层借助了 Spring,通过依赖注入、AOP 应用、面向接口编程,来降低业务组件之间的耦合度,增强系统扩展性。Spring 设计方案:平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,
32、如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除15 IOC(Inversion of Control),译作反转控制,其功能是将类之间的依赖转移到外部的配置文件中,避免在调用类中硬编码实现类,因此也被称作依赖注入(Dependency Injection)。在以往的开发中,通常利用工厂模式(Factory)来解决此类问题,其实不管是工厂模式还是依赖注入,调用类与实现类不可 能没有任何依赖,工厂模式中工厂类通常根据参数来判断该实例化哪个实现类,Spring IOC 将需要实例的 类在配置文件文件中配置。使用 Spring IOC 能得到工厂模式同样的效
33、果,而且编码更加简洁。需要指出的是本系统所有的事务管理,资源管理的 AOP 方案都是配置在本层的接口之上,利用 Java 对接口的动态代理技术实现,特别注意方法命名规范,防止资源泄露。4.数据持久层 本系统与数据库进行数据交互非常大,通常我们归为 CRUD(添加、读取、修改、删除),这些操作占据了系统开发中大部分的时间,同时我们还需要考虑与数据库交互的性能问题,如连接池、数据缓存等等。因此该层实现借助了Hibernate。而 Hibernate 已经成为事实上的轻量级 ORM 标准,在某此方面甚至超越了实体 EJB 的功能。Hibernate 是一个 ORM 工具,它不仅仅是实现了数据库访问性
34、能优化和与数据库交互的常用操作(CRUD),还将数据表与对象进行了 关联,让开发人员可以脱离数据表,而直接针对对象来与数据库交互,开发人员不再需要用字符串去描述表中字段,这使得编码中可书写性提高。平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处
35、,请联系改正或者删除16 在本系统中已经抽象出了一个 CRUD DAO 组件基类,利用 JDK5.0 的泛型技术,每个继承此组件基类的 DAO 都持有自身的持久对象类型,非常方便操作。在此基类中涵盖了大多数数据库操作方法,如 CRUD,分页,属性查询等。5.域对象层 该层应该说是 ORM 思想的产物,ORM 用对象关联数据表,将这些对象的集合归为一个专门的层即 Domain Layer。域对象是各层之间数据通信的载体。实际上域对象也是一个完完全全的业务对象,如 User 对象、Book 对象。通过对业务的对象化,这有利于业务逻辑的重用。在传统的多层 J2EE 系统中,为了防止层与层之间的互相侵
36、入性,通常采用 DTO(Data Transfer Object 数据传输对象)方式,不过本系统层次与业务并不复杂,侵入性也不会太高,为了性能上的考虑,决定使用 PO(Persistence Object 持久对象)来取代 DTO,个别复杂情况除外。6.WEB 层 JSP2.0 的特点是:使动态网页的设计更加容易 简化 JSP 页面,使得 JSP 页面容易维护 使 WEB 应用程序前后台应用更清晰 无需学习 Java 编程语言就可以编写 JSP 页面 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平
37、台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除17 本系统需要严格按照 JSP2.0 规范编写,具体 JSP2.0 规范请参考 JSP2.0 技术手册。本系统 Struts2 所有的 Action 对象继承 ActionSupport 基类,由前端注入拦截器(interceptor)将 Spring 业务处理对象自动装配到 Struts2 Action 之中,开发
38、人员不须手动管理业务处理对象的实例化。Struts2 配置文件需要按模块进行分类。具体 Struts2 使用方式请参考 Struts2 in Action。7.任务调度 本系统中含有大量的时间任务调度功能要求,如每天凌晨 2:00 进行内容索引更新,每月第一天 00:00 将最活跃用户算出增加积分等。Quartz 使用Trigger,Job 以及 JobDetail 等对象来进行各种类型的任务调度。Quartz 可以用来创建简单或为运行十个,百个,甚至是好几万个 Jobs 这样复杂的日程序表,这是 asp,php,甚至 等其它开发平台望尘莫及的。使用这种技术,可以满足我们的足够复杂的业务逻辑。
39、8.Ajax 技术 当今互联网时代,Ajax 技术已经是这个领域的技术领头羊,Web2.0 网站的核心技术也是以 Ajax 为中心,为了最高层次地提高用户的体验,必须使用Ajax 技术,本系统主要使用 JQuery 和 Ext 框架来实现 Ajax 技术。平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之
40、处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除18 四、系统缓存 1.一般缓存策略 空间换取时间,缓存永远计算机设计的重中之重,从 cpu 到 io,到处都可以看到缓存的身影,web 架构设计重,缓存设计必不可少,设计 web 缓存和企业级缓存是非常不同的,企业级缓存偏重于逻辑,而 web 缓存,简单快速为好。缓存的使用也会带来的问题,它使程序的复杂度上升,因为数据散布在多个进程,所以同步就是一个麻烦的问题,加上集群,复杂度会进一步提高,在实际运用中,采用怎样的同步策略常常需要和业务绑定。Cache 的常用的策略是:让数据在内存中,而不是在比较耗时的磁盘上。从
41、这个角度上思考,我们采用三种方式进行系统缓存。2.Hibernate 二级缓存 使用 EhCache 组件进行数据对象缓存,并设置缓存对象的缓存方式,如下所示:a)只读缓存(read-only):没有什么好说的 b)读/写缓存(read-write):程序可能要的更新数据 c)不严格的读/写缓存(nonstrict-read-write):需要更新数据,但是两个事务更新同一条记录的可能性很小,性能比读写缓存好 d)事务缓存(transactional):缓存支持事务,发生异常的时候,缓存也能够回滚,只支持 JTA 环境 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架
42、构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除19 读写缓存和不严格读写缓存在实现上的区别在于,读写缓存更新缓存的时候会把缓存里面的数据换成一个锁,其他事务如果去取相应的缓存数据,发现被锁住了,然后就直接取数据库查询。在 hibernate 的 ehcache 实现中,如果锁住部分缓存的事务发生
43、了异常,那么缓存会一直被锁住,直到 60 秒后超时。不严格读写缓存不锁定缓存中的数据。3.JSP 页面缓存 本系统中 OSCache 使用来实现 JSP 页面缓存功能,有 cache 的地方,session 就不能用了。搜索页面部分不要用 cache,每个人搜索的内容都不一样。关键子的定义,每个页面的关键子当然都不一样的,另外如果有分页,得把分页参数取得,放入关键字里,(不然的话,每页内容都一样了),如果还有其他的传入参数,比如查看不同分类,会有不同分类的 ID,也要放到关键字里。五、软件成本比较 软件/工具名称 J2EE 平台.Net 平台 比较 名称 参考价格(RMB)名称 参考价格(RM
44、B)服务器操作系统 Linux/Unix 免费 Windows Server2003 企业版 39,946 Linux 做服务器比Windows 更安全可靠和稳定 应用服务器 JBoss 免费 IIS 服务器自带组件 JBoss 支持企业级中间件技术、应用分布式技平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的资料内容仅供您学习参考,如
45、有不当之处,请联系改正或者删除 资料内容仅供您学习参考,如有不当之处,请联系改正或者删除20 术,并提供多个操作系统的版本 开发工具 Eclipse 免费 Visual S 24,753 Eclipse 开源,并有大量的开发插件使用,能提高开发效率 结点数据库 MySql 免费 Sql Server2000(一个 CPU)213,600 MySql 安装简单方便,速度快,易于维护,更适合系统节点使用。中心数据库 Oracle 同洲已购买 平台的概念的优势相关核心技术轻量级架构二应用部署架构服务器操作系统服务器架构系统数据库三开发关键技术软 面缓存五软件成本比较一技术平台是建立在平台上的企业级应用的解决方案技术的基础便是平台不但有平台的所有功 料内容仅供您学习参考如有不当之处请联系改正或者删除为一个支持企业级应用开发的体系结构简化企业解决方案的