


下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选文档Java架构设计1.目标:统一供应基础代码实现。 统一供应框架结构,并在此基础上逐步增加各种服务接口,使更多更好的服务在一个统一的层面供应,提升整体扩展力量。统一供应一些基础的和标准的服务,满足架构自身的服务要求。 定义界面标准组成模块和元素,使能够更加有力地推动界面风格设计和改进,提升友好性。供应模块插拔管理 支持集群,支持负载均衡。2.原则:开放性原则,架构各模块设计均依据此原则,支持在各个层次和各种模块上集成,提高兼容性。模块化原则,模块化是化解软件广度简单的必定手段,我们照旧奉行这一原则。分层原则,分层是为了降低软件深度简单性而使用的关键思想,表现/业务/数据访问这一标准的三层
2、次结构照旧是近10年来软件业最有力的武器。接口实现分别原则细节隐蔽原则,不能隐蔽细节就不能提升。依靠倒置原则,保证架构的可扩展性。3.方案:整个架构接受(页面框架/页面生成和流转/服务层/统一数据访问层)4层框架结构。页面框架负责客户端页面的布局和组织,接受AJAX实现。UI交互,呈现,页面流转接受JSF(Facelets)作呈现框架。页面风格接受统一的CSS来把握,Portal供应多套的风格模版。统一接受(类)SDO作为数据对象标准。定义对象标识标准,定义元数据标准,定义数据和元数据统一描述标准和统肯定位(URL)。服务层照旧接受POJI,集成现存服务,并额外供应以下几种基础服务: i.对象
3、描述服务,给出ID和类型,系统就能够给出有关对象的精确清楚的描述。 ii.对象定位服务,供应从一个对象自由地跳转到相关对象的服务。 iii.模糊搜寻,通过支持Lucene,供应系统全部对象的统一模糊查询。 iv.动态创建对象类型服务和对象类型管理服务。 v.统一对象(CRUD)管理服务 vi.JMX服务,借以供应动态配置管理服务。(优先级低)vii. 支持SOA流程。 数据访问层接受compass/JDBC实现统一的数据访问功能,支持现有代码。 i.供应按对象检索,生成更新,查询语句的功能。 ii.查询结果均接受对象和列表(类hibernate方式)。照旧接受Spring做统一对象管理和事务管
4、理。统一报表服务。论java架构设计软件架构作为一个概念,体现在技术和业务两个方面。从技术角度来说:软件架构随着技术的革新不断地更新其内容,软件架构建立于当前技术和一些基本原则的基础之上。先说一些基本原则:分层原则:分层是为了降低软件深度简单性而使用的关键思想,就像社会有了阶级一样,软件有了层次结构。模块化原则:模块化是化解软件广度简单的必定手段,模块化的目的就是让软件分工。接口实现分别原则随着软件模块化的不断深化改进,面对接口编程而不是面对实现编程可以让简单度日趋增高的软件降低模块之间的耦合度,从而让各模块更轻松改进。从这个原则动身,软件也从微观进行了细致的规范化。还有两个比较小但很重要的原
5、则:细节隐蔽原则很明显把简单问题简化,把难看的细节隐去,能让软件结构更清楚。其实这个原则使用很普遍,java/c+语言中的封装原则以及设计模式中的Facade(外观)模式就很能体现这个原则的精神。依靠倒置原则随着软件结构的进一步进展,层与层之间、模块与模块之间的依靠渐渐加深,而层、模块的动态可插拔要求不端增大。依靠倒置原则可看视为接口实现分别原则的深化,依据此原则的精神,软件进入了工具时代。这个原则有点类似于知名的好莱坞法则:Don't call us, we'll call you。以上这些原则奠定了我们的软件架构的价值指标。但软件架构到底是建立在当前技术之上的。而每一代技术
6、都有架构模式。过去的不再说了,让我们现在就来看一下当前流行的技术,以及当前我们能接受的架构。由于面对对象是当前最流行开发技术,且设计模式的大量使用使面对对象的走向成熟,而数据库是当前最有效的存储结构、web界面是当前最流行的用户接口,所以当前最典型的三层次架构就架构在以上几项技术的基础之上,用数据库作存储层、用面对对象来实现业务层、用web来作为用户接口层。我们从三层次架构谈起:由于面对对象技术和数据库技术不适配,所以在标准三层次架构的基础上,我们增加了数据长久层,来管理O-R双向映射,但目前始终没有最抱负的实现技术。cmp和entity bean技术由于其实现简单,功能前景有限,已接近被淘汰
7、的边缘。JDO及hibernate作为o-r映射的后期之秀,尤其是hibernate,功能相当完备。推举作为长久层的首选在业务层,由于当前业务日趋负载,且变动频繁,所以我们必需有足够灵敏的技术来保证我们的适应变化的力量,在标准j2ee系统中session bean负责业务处理,且有不错的性能表现,但接受ejb系统对业务架构模式转变太大,且其简单而昂贵,业务代码移植性差。而spring 作为一个bean配置的轻量级架构,秀丽的IOC模式实现,对业务架构影响小,所以推举作为中间层业务框架。在用户结构层,虽然servlet/jsp/jstl/javaBean 能够实现MVC架构,但终究过于粗糙。st
8、ruts对MVC架构的实现就比较完善,Taperstry也极好地实现MVC架构,且接受基于大事的方式,格外迷人,惜其不够成熟,我们照旧推举struts作为用户接口层基础架构。由于业务层是三层次架构中最有打算意义的,所以让我们回到业务层细致地分析一下,在简单的业务我们经常需要以下基础服务的一种或几种:事务全都性服务acid(tool:jta/jts)、并发加锁服务concurrent&&lock、池化管理服务cache、访问把握服务(tool:jaas)、流程把握服务workflow、动态实现服务IOC,串行化消息服务(tool:jms)、负载平衡服务blance等。假如我们不接
9、受重量级应用服务器(如weblogic,websphere,jboss等)及重量级组件(EJB),我们必需自己实现其中一些服务。虽然我们大多状况下,不需要全部这些服务,但实现起来却非易事。幸运的是我们有大量的开源实现代码,但接受开源代码却经常是件不轻松的事。随着xml作为结构化信息传输和存储地位日渐重要,一些xml文档操作工具(DOM,Digester,SAX等)的使用愈发重要,而随着xml schema的java binding工具(jaxb,xmlbean等)工具的成熟,接受xml schema来设计xml文档格式,然后接受java binding来生成java bean 会成为主要编程模
10、式,而这又进一步使数据中心向xml转移,使在中小数据量上,愈发倾向于以xquery为查询语言的xml数据库。最近还有一个趋势,microsoft,ibm等纷纷大量开发中间软件如(microsoft office之infopath),可以直接从xml schema 生成 录入页面等格外有用的功能。还有web service 的广泛应用,都将对软件的架构有格外重大的影响。至于面对服务架构(SOA)前景如何,三层次架构什么时候走入历史,现在还很难定论。aop的进展也会对软件架构有很深的影响,但在面对对象架构里,无论aspectJ还是jboss-aop抑是aspectWerks、nanning都有其自
11、身的严峻问题:维护性很差,所以说它将很难走远。或许作为一个很好的思想,它将在web service里大展身手。rdf,owl作为w3c语义模型的标志性的语言,也很难想象能在当前业务架构发挥太大影响。但假如真如它所声称那样,广泛地转变着信息的结构。那么对软件架构也会有深远影响。有关架构设计的一些忠告:尽量建立完整的长久对象层.可获得高回报尽量将各功能分层,分块,每一模块均依靠假定的其它模块的外观不能依靠静态数据来实现IOC模式,应当依靠数据特征接口,静态数据仅是数据特征接口实现方式之一架构设计时xml是支持而不是依靠.但可以供应单一的xml版本的实现从业务角度说:软件架构应是深刻体现业务内部规章
12、的业务架构,但由于业务变化频纴,所以软件架构很难保持恒定不变,但业务的频繁变化不应是软件架构大规模频繁变化的缘由,软件架构应是基于变化的架构。一种业务有其在一段时间内稳定存在的理由(暂且不谈),业务内部有很多用例,每一种用例都有固定的规章,每一规章都有一些可供判定的项,每一项从某一维度来观看都是可测量的,我们的架构首先必需保证完善适应每一项每一种测量方式,很多失败的架构都是由于很多项的测量方式都发生变更这种微观变化中。每个用例都有规章,我们在作业务用例分析,经常假定一些规章是先验的,长久稳定的,然而后来的业务转变经常又证明这种看法是错误的,然而经常我们的架构已经为之付出了不行挽回的代价。大量事
13、实证明:规章的变化经常用例变化的根本缘由。所以我们的架构要尽可能适应规章的变化,尽可能建立规章模版。每个用例都关系着不同的角色。每一个用例的产生都必定是由于角色的变更(留意:不是替换,而是增加或减弱),所以留意角色的各种可能状况,对架构的设计有举足轻重的意义。在我们当前的三层架构里,角色完善地对应接口概念。在一个系统里很多用例都相互关联,考虑到每个用例均有可能有不同的特例,所以在架构设计中,尽量接受依靠倒置原则。如架构许可可接受消息通信模式(JMS)。这样可降低耦合度。现在我们谈一下业务稳定存在理由对业务的影响。存在即是合理,在这里当然是正确的。业务因人而存在,所以问业务存在的理由即是问不同角
14、色的需要这项业务的理由以及宠爱不宠爱当前业务用例的理由,全部这样的角色都应当在系统里预留。待续在架构设计中有几个原则可以考虑:用例尽量细分用例尽量抽象角色尽量独立项测量独立原则追求简洁性这里未供应相关的例子,例子会在以后的更新时供应。业务和模式之间的关系业务中的一些用例之间的关系经常和一些常规的模式很相像。但随着时间的演化,渐渐地和从前的模式有了分歧。这是个正常的现象。但这对系统架构却要求格外高,要求系统架构能适应一些模式的更替。在这里我们尽可能早地留意到用例之间的相互角色变化,为架构更新做好预备.第一部分完.Spring对设计的影响Spring作为一种解耦合工具,在大型项目分模块开发时有效的
15、贯彻接口实现分别的原则,这一点格外重要。但Spring的lightweight只是针对编码来说是对的。对于设计却有深远影响。由于Spring推举使用接口来定义对象之间的关联,所以一般都接受接口实现分别来定义代码结构,这一点用不用Spring都应当如此,但用Spring更应当如此。Spring推举对对象之间的关联接受属性配置方式,设计时应尽量使用Bean方式来定义配置。但综合以上两点就会发觉,用一处配置两个相互关联的实例就很困难,由于一个对象A是通过B的接口来配置B属性的,不是直接通过B实例,而B的接口中一般没有配置指向A的属性,这个属性一般在B实例中。这样就无法通过一处配置使A、B双方相互关联,除非把配置指向A的SetXXX方法放置到B的接口中,但这样B的接口又不抱负。另一个方案是让B实现一个通用配置接口,但这又简单化了,还不如两处配置呢!两处配置的问题是简洁出错。还没
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 冰雪旅游项目2025年投资可行性区域旅游市场前景研究报告
- 智慧社区2025年大数据精准营销模型构建成果鉴定与社区服务创新报告
- 直接展示幼儿园数学试题及答案
- 建筑施工安全教育培训效果评估试题及答案
- 物理知识的深度2025年试题及答案
- 工业废气催化燃烧技术在冶金行业应用现状与环保策略报告
- 文艺团笔试题目及答案
- 有色金属资源循环利用产业链现状与2025年市场潜力分析报告
- 短视频平台内容监管与行业监管法律法规研究报告
- 施工现场安全数据分析试题及答案
- 电音节策划方案
- 贝恩杯案例分析大赛初赛题目
- 2023年江苏省南京市中考语文默写题复习(附答案解析)
- 全国各省市邮编对照表
- 行政区域代码表Excel
- YS/T 837-2012溅射靶材-背板结合质量超声波检验方法
- 烧烤类菜单表格
- DB11∕T 583-2022 扣件式和碗扣式钢管脚手架安全选用技术规程
- 酒水购销合同范本(3篇)
- 海康威视系统图标
- 印染厂管理手册
评论
0/150
提交评论