【Java精品源码栏目提醒】:本文主要为网学会员提供“java架构设计 - 生活指南”,希望对需要java架构设计 - 生活指南网友有所帮助,学习一下!
软件架构作为一个概念,体现在技术和业务两个方面。
从技术角度来说:软件架构随着技术的革新不断地更新其内容,软件架构建立于当前技术和一些基本原则的基础之上。
先说一些基本原则:分层原则:分层是为了降低软件深度复杂性而使用的关键思想,就像社会有了阶级一样,软件有了层次结构。
模块化原则:模块化是化解软件广度复杂的必然手段,模块化的目的就是让软件分工。
接口实现分离原则随着软件模块化的不断深入改进,面向接口编程而不是面向实现编程可以让复杂度日趋增高的软件降低模块之间的耦合度,从而让各模块更轻松改进。
从这个原则出发,软件也从微观进行了细致的规范化。
还有两个比较小但很重要的原则:细节隐藏原则很显然把复杂问题简化,把难看的细节隐去,能让软件结构更清晰。
其实这个原则使用很普遍,
java/c语言中的封装原则以及设计模式中的 Facade(外观)模式就很能体现这个原则的精神。
依赖倒置原则随着软件结构的进一步发展层与层之间、 模块与模块之间的依赖逐渐加深,而层、模块的动态可插拔要求不端增大。
依赖倒置原则可看视为接口实现分离原则的深化,根据此原则的精神,软件进入了工具时代。
这个原则有点类似于知名的好莱坞法则:Dont callus well call you。
但软件架构毕竟是建立在当前技术之上的。
以上这些原则奠定了我们的软件架构的价值指标。
而每一代技术都有架构模式。
过去的不再说了,让我们现在就来看一下当前流行的技术,以及当前我们能采用的架构。
因为面向对象是当前最流行开发技术,且设计模式的大量使用使面向对象的走向成熟,而数据库是当前最有效的存储结构、web 界面是当前最流行的用户接口,所以当前最典型的三层次架构就架构在以上几项技术的基础之上,用数据库作存储层、用面向对象来实现业务层、用 web 来作为用户接口层。
我们从三层次架构谈起:因为面向对象技术和数据库技术不适配,所以在标准三层次架构的基础上,我们增加了数据持久层,来管理 O-R 双向映射,但目前一直没有最理想的实现技术。
cmp 和 entity bean 技术因为其实现复杂,功能前景有限,已接近被淘汰的边缘。
JDO 及 hibernate 作为 o-r 映射的后期之秀,尤其是 hibernate,功能相当完备。
推荐作为持久层的首选在业务层因为当前业务日趋负载, 且变动频繁,所以我们必须有足够敏捷的技术来保证我们的适应变化的能力, 在标准 j2ee 系统中 session bean 负责业务处理,且有不错的性能表现,但采用 ejb 系统对业务架构模式改变太大,且其复杂而昂贵,业务代码移植性差。
而 spring作为一个 bean 配置的轻量级架构,漂亮的 IOC 模式实现,对业务架构影响小,所以推荐作为中间层业务框架。
在用户结构层虽然 servlet/jsp/jstl/javaBean 能够实现 MVC 架构但终究过于粗糙。
struts 对 MVC 架构的实现就比较完美,Taperstry 也极好地实现 MVC 架构,且采用基于事件的方式,非常诱人,惜其不够成熟,我们仍旧推荐 struts 作为用户接口层基础架构。
因为业务层是三层次架构中最有决定意义的,所以让我们回到业务层细致地分析一下,在复杂的业务我们常常需要以下基础服务的一种或几种:事务一致性服务 acidtool:jta/jts、并发加锁服务 concurrentlock、池化管理服务 cache、访问控制服务tool:jaas、流程 控制服务 workflow、动态实现服务 IOC,串行化消息服务tool:jms、负载平衡服务 blance等。
如果我们不采用重量级应用服务器如 weblogicwebspherejboss 等及重量级组件EJB,我们必须自己实现其中一些服务。
虽然我们大多情况下,不需要所有这些服务,但实现起来却非易事。
幸运的是我们有大量的开源实现代码但采用开源代码却常常是件不轻松的事。
随 着 xml 作 为 结 构 化 信 息 传 输 和 存 储 地 位 日 渐 重 要 一 些 xml 文 档 操 作 工 具DOMDigesterSAX 等 的 使 用 愈 发 重 要 而 随 着 xml schema 的
java binding 工 具jaxbxmlbean 等工具的成熟, 采用 xml schema 来设计 xml 文档格式然后采用
java binding来生成
java bean 会成为主要编程模式而这又进一步使数据中心向 xml 转移使在中小数据量上愈发倾向于以 xquery 为查询语言的 xml 数据库。
最近还有一个趋势microsoftibm 等纷纷大量开发中间软件如microsoft office 之 infopath, 可以直接从 xml schema 生成 录入页面等非常实用的功能。
还有 web service 的广泛应用,都将对软件的架构有非常重大的影响。
至于面向服务架构SOA前景如何,三层次架构什么时候走入历史,现在还很难定论。
aop 的发展也会对软件架构有很深的影响, 无论 aspectJ 还是 jboss-aop 但在面向对象架构里,抑是 aspectWerks、nanning 都有其自身的严重问题:维护性很差所以说它将很难走远。
也许作为一个很好的思想,它将在 web service 里大展身手。
rdfowl 作为 w3c 语义模型的标志性的语言也很难想象能在当前业务架构发挥太大影响。
但如果真如它所声称那样,广泛地改变着信息的结构。
那么对软件架构也会有深远影响。
有关架构设计的一些忠告:尽量建立完整的持久对象层.可获得高回报尽量将各功能分层分块每一模块均依赖假定的其它模块的外观不能依赖静态数据来实现 IOC 模式,应该依赖数据特征接口,静态数据仅是数据特征接口实现方式之一架构设计时 xml 是支持而不是依赖.但可以提供单一的 xml 版本的实现从业务角度说:软件架构应是深刻体现业务内部规则的业务架构,但因为业务变化频纴,所以软件架构很难保持恒定不变,但业务的频繁变化不应是软件架构大规模频繁变化的原因,软件架构应是基于变化的架构。
一种业务有其在一段时间内稳定存在的理由暂且不谈,业务内部有许多用例,每一种用例都有固定的规则, 每一项从某一维度来观察都是可测量的, 每一规则都有一些可供判定的项,我们的架构首先必须保证完美适应每一项每一种测量方式,很多失败的架构都是因为很多项的测量方式都发生变更这种微观变化中。
每个用例都有规则,我们在作业务用例分析,常常假定一些规则是先验的,持久稳定的,然而后来的业务改变常常又证明这种看法是错误的,然而常常我们的架构已经为之付出了不可挽回的代价。
大量事实证明:规则的变化常常用例变化的根本原因。
所以我们的架构要尽可能适应规则的变化,尽可能建立规则模版。
每个用例都关系着不同的角色。
每一个用例的产生都必然是因为角色的变更(注意:不是替换,而是增强或减弱),所以注意角色的各种可能情况,对架构的设计有举足轻重的意义。
在我们当前的三层架构里,角色完美地对应接口概念。
所以在架构设计在一个系统里很多用例都相互关联考虑到每个用例均有可能有不同的特例,中,尽量采用依赖倒置原则。
如架构许可可采用消息通信模式JMS。
这样可降低耦合度。
现在我们谈一下业务稳定存在理由对业务的影响。
存在即是合理,在这里当然是正确的。
业务因人而存在,所以问业务存在的理由即是问不同角色的需要这项业务的理由以及喜欢不喜欢当前业务用例的理由,所有这样的角色都应该在系统里预留。
《待续》在架构设计中有几个原则可以考虑:用例尽量细分用例尽量抽象角色尽量独立项测量独立原则追求简单性这里未提供相关的例子,例子会在以后的更新时提供。
业务和模式之间的关系业务中的一些用例之间的关系常常和一些常规的模式很相似。
但随着时间的演化,慢慢地和先前的模式有了分歧。
这是个正常的现象。
但这对系统架构却要求非常高,要求系统架构能适应一些模式的更替。
在这里我们尽可能早地注意到用例之间的相互角色变化,为架构更新做好准备.1. 目标:统一提供基础代码实现。
统一提供框架结构,并在此基础上逐步增加各种服务接口,使更多更好的服务在一个统一的层面提供,提升整体扩展能力。
统一提供一些基础的和标准的服务,满足架构自身的服务要求。
定义界面标准组成模块和元素,使能够更加有力地推动界面风格设计和改进,提升友好性。
提供模块插拔管理 支持集群,支持负载均衡。
2. 原则:开放性原则,架构各模块设计均依据此原则,支持在各个层次和各种模块上集成,提高兼容性。
模块化原则,模块化是化解软件广度复杂的必然手段,我们依然奉行这一原则。
分层原则,分层是为了降低软件深度复杂性而使用的关键思想,表现/业务/数据访问这一标准的三层次结构依然是近 10 年来软件业最有力的武器。
接口实现分离原则细节隐藏原则,不能隐藏细节就不能提升。
依赖倒置原则,保证架构的可扩展性。
3. 方案:整个架构采用(页面框架/页面生成和流转/服务层/统一数据访问层)4 层框架结构。
页面框架负责客户端页面的布局和组织,采用 AJAX 实现。
UI 交互,展现,页面流转采用 JSF(Facelets)作展现框架。
页面风格采用统一的 CSS 来控制,Portal 提供多套的风格模版。
统一采用类SDO 作为数据对象标准。
定义对象标识标准,定义元数据标准,定义数据和元 。
数据统一描述标准和统一定位(URL)服务层依然采用 POJI,集成现存服务,并额外提供以下几种基础服务:i. 对象描述服务,给出 ID 和类型,系统就能够给出有关对象的准确清晰的描述。
ii. 对象定位服务,提供从一个对象自由地跳转到相关对象的服务。
iii. 模糊搜索,通过支持 Lucene,提供系统所有对象的统一模糊查询。
iv. 动态创建对象类型服务和对象类型管理服务。
v. 统一对象(CRUD)管理服务 (优先级低)vi. JMX 服务,借以提供动态配置管理服务。
vii. 支持 SOA 流程。
数据访问层采用 compass/JDBC 实现统一的数据访问功能,支持现有代码。
i. 提供按对象检索,生成更新,查询语句的功能。
ii. 查询结果均采用对象和列表(类 hibernate 方式)。
依然采用 Spring 做统一对象管理和事务管理。
统一报表服务。
模式在软件系统中的使用粒度越来越大也越来越方便通常视而不见的模式有:管理模式(可管理性)JMXURL 模式(可定位性)对象定位搜索模式(可联想搜索)lucene描述模式(信息的可描述性)字典代码/名称配置模式(可配置性)IOC规则模式(可定义为规则)Drools分发模式(支持统一分散特性)MVC/动态 URL插件模式(可组装性Eclipse/动态菜单模版模式(可模版化)velocity/cocoon/xslt流程模式(可定义流程)shark/state machineAop/Filter 模式(功能细分/组装模式)消息队列模式(可排队和异步处理模式)JMS事务ACIDJTA锁模式(concurrent集群模式(treeCache统一服务端口模式(EndPoint)Mule/ServiceMix/ESB
上一篇:
程序员的简历制作
下一篇:
bc80e7a0-d1f2-4595-b21d-01a76798e87a