J2EE系统设计方案_第1页
J2EE系统设计方案_第2页
J2EE系统设计方案_第3页
J2EE系统设计方案_第4页
J2EE系统设计方案_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

J2EE系统技术方案J2EE系统技术方案 1一、 技术平台 21. J2EE的概念 32. J2EE的优势 33. J2EE有关核心技术 44. 轻量级J2EE架构 5二、 应用布署架构 61. 服务器操作系统 62. Web服务器架构 63. 系统数据库 6三、 开发核心技术 71. 软件版本与工具 72. 重要技术方案 83. 业务逻辑层 94. 数据持久层 95. 域对象层 96. WEB层 107. 任务调度 108. Ajax技术 10四、 系统缓存 101. 普通缓存方略 102. Hibernate二级缓存 113. JSP页面缓存 11五、 软件成本比较 11技术平台J2EE(Java2EnterpriseEdition)是建立在Java2平台上的公司级应用的解决方案。J2EE技术的基础便是Java2平台,不仅有J2SE平台的全部功效,同时还提供了对EJB,Servlet,JSP,XML等技术的全方面支持,其最后目的是成为一种支持公司级应用开发的体系构造,简化公司解决方案的开发,布署和管理等复杂问题。事实上,J2EE已经成为公司级开发的工业原则和首选平台。市场上能够看到诸多实现了J2EE的产品,如BEAWebLogic,IBMWebSphere以及开源的JBoss等等。J2EE并非一种产品,而是一系列的原则,它是由sun公司提出的,符合这个原则的产品叫"实现"。J2EE的概念现在,Java2平台有3个版本,它们是合用于小型设备和智能卡的Java2平台Micro版(Java2PlatformMicroEdition,J2ME)、合用于桌面系统的Java2平台原则版(Java2PlatformStandardEdition,J2SE)、合用于创立服务器应用程序和服务的Java2平台公司版(Java2PlatformEnterpriseEdition,J2EE)。J2EE是一种运用Java2平台来简化公司解决方案的开发、布署和管理有关的复杂问题的体系构造。J2EE技术的基础就是核心Java平台或Java2平台的原则版,J2EE不仅巩固了原则版中的许多优点,例如"编写一次、随处运行"的特性、方便存取数据库的JDBCAPI、CORBA技术以及能够在Internet应用中保护数据的安全模式等等,同时还提供了对EJB(EnterpriseJavaBeans)、JavaServletsAPI、JSP(JavaServerPages)以及XML技术的全方面支持。其最后目的就是成为一种能够使公司开发者大幅缩短投放市场时间的体系构造。J2EE体系构造提供中间层集成框架用来满足无需太多费用而又需要高可用性、高可靠性以及可扩展性的应用的需求。通过提供统一的开发平台,J2EE减少了开发多层应用的费用和复杂性,同时提供对现有应用程序集成强有力支持,完全支持EnterpriseJavaBeans,有良好的向导支持打包和布署应用,添加目录支持,增强了安全机制,提高了性能。J2EE的优势

J2EE为搭建含有可伸缩性、灵活性、易维护性的商务系统提供了良好的机制。

这之因此成为可能是由于J2EE拥有广泛的业界支持和某些重要的'公司计算'领域供应商的参加。每一种供应商都对现有的客户提供了不用废弃已有投资,进入可移植的J2EE领域的升级途径。由于基于J2EE平台的产品几乎能够在任何操作系统和硬件配备上运行,现有的操作系统和硬件也能被保存使用。高效的开发:J2EE允许公司把某些通用的、很繁琐的服务端任务交给中间件供应商去完毕。这样开发人员能够集中精力在如何创立商业逻辑上,对应地缩短了开发时间。高级中间件供应商提供下列这些复杂的中间件服务。状态管理服务:让开发人员写更少的代码,不用关心如何管理状态,这样能够更快地完毕程序开发。持续性服务:让开发人员不用对数据访问逻辑进行编码就能编写应用程序,能生成更轻巧,与数据库无关的应用程序,这种应用程序更易于开发与维护。分布式共享数据对象CACHE服务--让开发人员编制高性能的系统,极大提高整体布署的伸缩性。支持异构环境:J2EE能够开公布署在异构环境中的可移植程序。基于J2EE的应用程序不依赖任何特定操作系统、中间件、硬件。因此设计合理的基于J2EE的程序只需开发一次就可布署到多个平台。这在典型的异构公司计算环境中是十分核心的。J2EE原则也允许客户订购与J2EE兼容的第三方的现成的组件,把他们布署到异构环境中,节省了由自己制订整个方案所需的费用。可伸缩性:公司必须要选择一种服务器端平台,这种平台应能提供极佳的可伸缩性去满足那些在他们系统上进行商业运作的大批新客户。基于J2EE平台的应用程序可被布署到多个操作系统上。例如可被布署到高端UNIX与大型机系统,这种系统单机可支持64至256个解决器。(这是NT服务器所望尘莫及的)J2EE领域的供应商提供了更为广泛的负载平衡方略。能消除系统中的瓶颈,允许多台服务器集成布署。这种布署可达数千个解决器,实现可高度伸缩的系统,满足将来商业应用的需要。稳定的可用性:J2EE布署到可靠的操作环境中,支持长久的可用性。某些J2EE布署在WINDOWS环境中,客户也可选择强健性能更加好的操作系统如Linux,SunSolaris、IBMOS/390。J2EE有关核心技术J2EE的多个组件、服务和API,进行更加具体的叙述,在开发不同类型的公司级应用时,根据各自需求和目的的不同,应当如何灵活使用并组合不同的组件和服务。Servlet

Servlet是Java平台上的CGI技术。Servlet在服务器端运行,动态地生成Web页面。与传统的CGI和许多其它类似CGI的技术相比,JavaServlet含有更高的效率并更容易使用。对于Servlet,重复的请求不会造成同一程序的多次转载,它是依靠线程的方式来支持并发访问的。JSP

JSP(JavaServerPage)是一种实现普通静态HTML和动态页面输出混合编码的技术。从这一点来看,非常类似MicrosoftASP、PHP等技术。借助形式上的内容和外观体现的分离,Web页面制作的任务能够比较方便地划分给页面设计人员和程序员,并方便地通过JSP来合成。在运行时态,JSP将会被首先转换成Servlet,并以Servlet的形态编译运行,因此它的效率和功效与Servlet相比没有差别,同样含有很高的效率。JDBC

JDBC(JavaDatabaseConnectivity,Java数据库连接)API是一种原则SQL(StructuredQueryLanguage,构造化查询语言)数据库访问接口,它使数据库开发人员能够用原则JavaAPI编写数据库应用程序。JDBCAPI重要用来连接数据库和直接调用SQL命令执行多个SQL语句。运用JDBCAPI能够执行普通的SQL语句、动态SQL语句及带IN和OUT参数的存储过程。Java中的JDBC相称与Microsoft平台中的ODBC(OpenDatabaseConnectivity)。JMS

JMS(JavaMessageService,Java消息服务)是一组Java应用接口,它提供创立、发送、接受、读取消息的服务。JMSAPI定义了一组公共的应用程序接口和对应语法,使得Java应用能够和多个消息中间件进行通信,这些消息中间件涉及IBMMQ-Series、MicrosoftMSMQ及纯Java的SonicMQ。通过使用JMSAPI,开发人员无需掌握不同消息产品的使用办法,也能够使用统一的JMSAPI来操纵多个消息中间件。通过使用JMS,能够最大程度地提高消息应用的可移植性。JMS既支持点对点的消息通信,也支持公布/订阅式的消息通信。JNDI

由于J2EE应用程序组件普通分布在不同的机器上,因此需要一种机制方便于组件客户使用者查找和引用组件及资源。在J2EE体系中,使用JNDI(JavaNamingandDirectoryInterface)定位多个对象,这些对象涉及EJB、数据库驱动、JDBC数据源及消息连接等。JNDIAPI为应用程序提供了一种统一的接口来完毕原则的目录操作,如通过对象属性来查找和定位该对象。由于JNDI是独立于目录合同的,应用还能够使用JNDI访问多个特定的目录服务,如LDAP、NDS和DNS等。轻量级J2EE架构现在J2EE应用中,由于应用需求不同,架构设计上分成两种设计方式,即重量级J2EE架构和轻量级J2EE架构。银行,电信,大型公司的业务系统逻辑复杂,结点分布广泛,且普遍使用了物理上多层架构,事务规定性极高,对系统的稳定性规定也是极高的,因此大多数使用重量级的EJB开发架构。普通的中小型应用系统,所关注的是访问速度与快速响应市场需求变化,强大的系统缓存功效,传统的大型分布式J2EE架构就显得不太适宜。本系统的开发基于J2EE的轻量级多层架构,即业界比较成熟的Struts2+Spring+Hibernate框架:Struts2实现MVC最为成熟的框架之一,在J2EE项目中应用广泛;Spring能够实现对Hibernate的无缝链接,合用于业务解决层;在数据持久层中,采用Hibernate这一功效强大的ORM映射工具。J2EE的三层构造在业界是指表达层(Presentation),业务逻辑层(Businesslogic)以及基础架构层(Infrastructure)。一种最惯用的扩展就是将三层体系扩展为五层体系,即表达层(Presentation)、控制/中介层(Controller/Mediator)、领域层(Domain)、数据持久层(DataPersistence)和数据源层(DataSource)。它其实是在三层架构中增加了两个中间层。控制/中介层位于表达层和领域层之间,数据持久层位于领域层和基础架构层之间。而轻量级架构Struts2+Spring+Hibernate能够实现J2EE多层构造,Struts2用于表达层、控制层,Spring用于业务解决层,而Hibernate用于数据持久层。应用布署架构服务器操作系统GSR系统将运行在Linux操作系统,Linux最大的优点在于它作为服务器操作系统的强大功效,尚有它的可靠的性能,稳定性与网络安全性,是大型公司和网络中心加高服务器首选的操作系统,它提供了最惯用最广泛使用的诸如负载均衡,远程镜像等集成解决方案。J2EE作为一种跨操作系统平台的应用系统平台,在Linux上面能够体现出非常好的性能。Web服务器架构JBoss是一种运行EJB的强健的、高质量的和性能良好的J2EE应用服务器。它是开放源代码的项目,遵照最新的J2EE规范。从JBoss项目开始至今,它已经从一种EJB容器发展成为一种基于的J2EE的一种web操作系统。含有革命性的JMX微内核服务作为其总线构造;面对服务的架构(Service-OrientedArchitecture,SOA);含有统一的类装载器,从而能够实现应用的热布署和热卸载能力。JBoss集成了Tomcat做为Web服务器,Tomcat优点是免费,实现J2ee规范最佳的应用服务器,能够极大地减少甲方的运行成本。Tomcat是Apache的核心项目之一,也被SUN视作Servlet/JSP容器的一种重要参考实现而加以支持。因此SUN最新的Servlet/JSP规范,往往能够很快地在Tomcat的新版本中得到体现;Tomcat是一种小巧精巧的web应用服务器,配备、安装、运行、布署web应用都很简朴;Tomcat与开源紧密结合,开源软件的生命力,往往与其社区的状况有紧密的联系。总而言之,采用此种服务器配备方案无论从成本上还是系统性能和安全上考虑都是非常适宜的。系统数据库中心数据库系统使用Oracle10g,oracle是业界各方面最佳的数据库。节点数据库使用MySQL,MySQL是最流行的开放源码SQL数据库管理系统,它是由MySQLAB公司开发、公布并支持的。MySQL是一种关联数据库管理系统,它是一种开放源码软件。MySQL含有良好的扩展性,在数据访问上碰到瓶颈时,能够布署MySQL集群来实现负载均衡。开发核心技术软件版本与工具名称版本号阐明JavaSE6.0Java虚拟机版本号J2EE1.4J2EE平台版本号JSP2.0JSP界面编写版本规范JSTL1.1JSP原则标签库版本Servlet2.4Servlet引擎版本规范Struts2.1WEB层MVC框架版本Spring2.0轻量级业务逻辑层解决框架Xfire2.0WebService实现技术Hinbernate3.1ORM对象关系映射层版本XHtml1.1Html书写版本规范CSS2.0Html样式版本规范JQuery2.2Ajax框架版本号Ext2.0Javascript类库Acige2.0权限控制框架开发工具:工具名称工具版本阐明Eclipse3.3JavaIDEMyEclipse6.0J2EE开发工具PowerDesigner12数据库设计工具JBoss4.2Java应用服务器版本号Tomcat6.0开发测试服务器Oracle10gMysql5.18数据库版本号重要技术方案系统架构图:从架构图中能够看出系统分为四层:UI层:借助JSP,Struts实现业务层:借助SpringFramework进行业务组件的组装关联。数据持久层:借助Hibernate实现域对象层:将全部域对象划分在一种层面采用这样的四层架构能够达成下列效果:通过成熟的开源产品实现各层,同自己编写代码实现,相比之下能缩短开发周期,且架构所用到的开源产品都有很广泛的顾客群,经受过实践的考验,质量和性能更有保障。层与层之间松散耦合,增加代码重用率。各层分工明确,这样也利于团体的明确分工。业务逻辑层在实际的项目开发中,每个领域都会有自己独特的业务逻辑,正由于这样,致使项目中代码高度耦合,原本有可能被重用的代码或功效,由于与具体的业务逻辑绑定在一块而造成很难被重用。因此我们将实现这些具体逻辑的代码抽取出来分为单独的一层,其目的是但愿通过层,来减少它与系统其它部分的耦合度。现实中世界是变化的,既然该层实现的是现实中具体的业务逻辑,那该层的实当代码不可避免的会发生变更。如何让该层适应最大的变化,做到最小的改动?普通我们在编码的时候会尽量考虑到同一业务多个实现的兼容和可扩展的能力。因此我们在该层借助了Spring,通过依赖注入、AOP应用、面对接口编程,来减少业务组件之间的耦合度,增强系统扩展性。Spring设计方案:IOC(InversionofControl),译作反转控制,其功效是将类之间的依赖转移到外部的配备文献中,避免在调用类中硬编码实现类,因此也被称作依赖注入(DependencyInjection)。在以往的开发中,普通运用工厂模式(Factory)来解决这类问题,其实不管是工厂模式还是依赖注入,调用类与实现类不可能没有任何依赖,工厂模式中工厂类普通根据参数来判断该实例化哪个实现类,SpringIOC将需要实例的类在配备文献文献中配备。使用SpringIOC能得到工厂模式同样的效果,并且编码更加简洁。需要指出的是本系统全部的事务管理,资源管理的AOP方案都是配备在本层的接口之上,运用Java对接口的动态代理技术实现,特别注意办法命名规范,避免资源泄露。数据持久层本系统与数据库进行数据交互非常大,普通我们归为CRUD(添加、读取、修改、删除),这些操作占据了系统开发中大部分的时间,同时我们还需要考虑与数据库交互的性能问题,如连接池、数据缓存等等。因此该层实现借助了Hibernate。而Hibernate已经成为事实上的轻量级ORM原则,在某此方面甚至超越了实体EJB的功效。Hibernate是一种ORM工具,它不仅仅是实现了数据库访问性能优化和与数据库交互的惯用操作(CRUD),还将数据表与对象进行了关联,让开发人员能够脱离数据表,而直接针对对象来与数据库交互,开发人员不再需要用字符串去描述表中字段,这使得编码中可书写性提高。在本系统中已经抽象出了一种CRUDDAO组件基类,运用JDK5.0的泛型技术,每个继承此组件基类的DAO都持有本身的持久对象类型,非常方便操作。在此基类中涵盖了大多数数据库操作办法,如CRUD,分页,属性查询等。域对象层该层应当说是ORM思想的产物,ORM用对象关联数据表,将这些对象的集合归为一种专门的层即DomainLayer。域对象是各层之间数据通信的载体。事实上域对象也是一种完完全全的业务对象,如User对象、Book对象。通过对业务的对象化,这有助于业务逻辑的重用。在传统的多层J2EE系统中,为了避免层与层之间的互相侵入性,普通采用DTO(DataTransferObject数据传输对象)方式,但是本系统层次与业务并不复杂,侵入性也不会太高,为了性能上的考虑,决定使用PO(PersistenceObject持久对象)来取代DTO,个别复杂状况除外。WEB层JSP2.0的特点是:

使动态网页的设计更加容易

简化JSP页面,使得JSP页面容易维护

使WEB应用程序前后台应用更清晰

无需学习Java编程语言就能够编写JSP页面本系统需要严格按照JSP2.0规范编写,具体JSP2.0规范请参考《JSP2.0技术手册》。本系统Struts2全部的Action对象继承ActionSupport基类,由前端注入拦截器(interceptor)将Spring业务解决对象自动装配到Struts2Action之中,开发人员不须手动管理业务解决对象的实例化。Struts2配备文献需要按模块进行分类。具体Struts2使用方式请参考《Struts2inAction》。任务调度本系统中含有大量的时间任务调度功效规定,如每天凌晨2:00进行内容索引更新,每月第一天00:00将最活跃顾客算出增加积分等。Quartz使用Trigger,Job以及JobDetail等对象来进行多个类型的任务调度。Quartz能够用来创立简朴或为运行十个,百个,甚至是好几万个Jobs这样复杂的日程序表,这是asp,php,甚至等其它开发平台望尘莫及的。使用这种技术,能够满足我们的足够复杂的业务逻辑。Ajax技术当今互联网时代,Ajax技术已经是这个领域的技术领头羊,Web2.0网站的核心技术也是以Ajax为中心,为了最高层次地提高顾客的体验,必须使用Ajax技术,本系统重要使用JQuery和Ext框架来实现Ajax技术。系统缓存普通缓存方略空间换取时间,缓存永远计算机设计的重中之重,从cpu到io,到处都能够看到缓存的身影,web架构设计重,缓存设计必不可少,设计web缓存和公司级缓存是非常不同的,公司级缓存偏重于逻辑,而web缓存,简朴快速为好。缓存的使用也会带来的问题,它使程序的复杂度上升,由于数据散布在多个进程,因此同时就是一种麻烦的问题,加上集群,复杂度会进一步提高,在实际运用中,采用如何的同时方略经常需要和业务绑定。Cache的惯用的方略是:让数据在内存中,而不是在比较耗时的磁盘

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论