`
xcy13638760
  • 浏览: 51521 次
社区版块
存档分类
最新评论

谈谈对于企业级系统架构的理解

 
阅读更多

导读:本文作者李平针对企业系统架构作出分析,发表独特见解,系统架构并不是一层不变的,没有最好的架构,只有更好的架构,要从实际情况去考虑,从项目中多思考系统的扩展性。

以下是文章内容:

在我们刚开始学习架构的时候,首先会想到分层的概念,分层架构比较经典的是三层架构,那么,什么是三层架构呢?它包括表现层,业务层,数据访问层;而对于一个新手来说,从抽象意义上的三层架构,逻辑上就划分为三个层。

image

这个是最基本的三层架构模式。

表现层充当系统的界面呈现以及UI逻辑的角色,也就是说,UI(用户界面)属于表现层;

举一个对于asp.net WebForm来说,人们喜欢把对于UI的控制逻辑(服务器控件的读取、设置、事件等等)写在页面的后置隐藏代码中,并且依赖业务逻辑层。当然,服务器控件支持数据绑定的功能,可以通过数据源进行绑定控件。这样就可以节省在后置隐藏中的代码。

因此,我们就可以把表现层分为UI用户界面以及UI逻辑:

image

UI用户界面的职责只是作为数据输入和输出后的展示工作。

UI逻辑的职责是负责业务逻辑层以及UI用户界面之间的数据交互,并且尽可能地让UI逻辑不依赖于UI技术。

其中UI用户界面的实现方式有很多,包括ASP.NET,WinForm,WPF,Silverlight,移动Web,智能设备等等。

image

将表现层中UI页面和UI逻辑分离的策略中,当前使用最多的两种模式是MVC模式和MVP模式。

MVC模式,即模型-视图-控制器模式,通过视图触发并执行某个操作,调用控制器,通过控制器去操作业务层,最终返回模型,在视图中进行展示。这里的模型可以是一个领域模型(DM),也可以是一个数据迁移对象(DTO)。

MVP模式,即模型-视图-展示器模式,和MVC模式有点像,不同的是MVP中视图和模型是被完全分离出来的,视图中定义一个接口,而展示器通过调用该接口的方法以控制视图。因此,视图和模型是松散的,展示器也充当了一个控制器的角色,同时它也不依赖于UI技术。

另外再介绍一种模式PM(Preentation Model),它可以说是MVP的变体,在PM中,视图不定义接口,这里的模型只是表示视图状态的类,视图中的元素被直接绑定到模型属性上。例如在WPF中,WPF就先天的具有数据双向绑定机制以及事件通知属性机制。

所以它特别适用于WPF,Sliverlight等等。

image

在开始业务层之前,不得不说一个前提,在一个小型项目中,直接让表现层调用业务层,足以解决所有问题。但是,当项目大到使用多种表现形式,如使用了各种UI技术,ASP.NET,WPF,移动设备等等,就要考虑在你的表现层和业务层之间增加一个层,以至于让表现层和业务层解耦,因为业务层作为一个业务中间件的平台,最好不要暴露于表现层中,这个层就是传说中的服务层。架构图又演化为:

image

服务层实际上并不执行任何具体的工作,其功能在于组织各个业务对象,服务层将业务层所有的细节对表现层都隐藏起来,服务器将组织业务逻辑层中的组件,并且通过数据迁移对象(DTO)与表现层交互,因此就产生一个DTO模型。

为了实现服务的可重用性,需要使用服务接口,表现层通过规定的接口访问功能。服务的实现继承服务接口,而服务的实现专注于业务层的调用。

image

对于服务层,常用的方法包括Web服务、.NET Remoting、Rest以及WCF技术。

本人比较建议使用WCF作为服务,因为可以方便地通过配置达到远程调用服务的目的。

服务层消除了两个表现层和业务层之间的耦合,服务层可以实现一个远程接口,达到多UI技术甚至多平台上的通信。

当然增加服务层也有缺点,假如使用WCF服务,会增加系统的调用开销,进而影响性能。

image

业务层中包含系统所需要业务过程上的实现,并与下层的数据访问层交互。

我们通常也叫做业务层叫做业务逻辑层,但我认为业务逻辑层是属于业务层的一方面,业务逻辑更专注于业务上逻辑算法的实现。因为业务层还可以包括其他的方面。

业务层必须包括对业务实体尽心建模的对象模型,表达了客户的所有策略和需求的业务规则,因此就产生了领域模型。

(PS:如果这里你不使用领域模型,那么需要采用业务规则层进行业务功能上的业务规则的验证和控制)

领域模型包括对实体的属性定义,方法定义以及实体与实体之间的关系。从这个角度上看,UML建模至关重要,通过对UML动态图和静态图的描述,可以映射到领域模型中。

从服务层刚才讲到了DTO模型,这里需要一个机制将DTO转化为领域模型,所以产生了DTO映射层(DTOMapper)。

另外业务层还包括核心中间件技术,包括第三方组件,以及工作流引擎等等。

image

业务层需要考虑到一些与数据访问层交互的设计模式,模式中包括事物脚本模式、表模块模式、活动记录模式、领域模型模式。

事物脚本模式是通过方法来执行业务流程,它是一个过程式模型,事物脚本的每个方法都有一个特定的事物脚本,它侧重于业务上一系列流程上的顺序操作,它实现起来很简单,但是它有个致命的缺点就是它会造成很多重复的代码。

表模块模式比起事物脚本模式,具有一定的结构,它的思想也很简单,每个数据表都定义一个业务组件(实体类,实体操作类),在.NET中更多的使用DataSet作为表模型的数据交互。但是它也有一个缺点就是它是从数据库驱动它不适合于大量的数据表以及数据表之间的复杂关系。

活动记录模式中的对象中,可以包含数据和方法。它接近于数据表的结构,它的对象中执行方法中可以包含CRUD操作,验证算法,以及其他的计算功能。一般来说,领域模型不是太复杂,活动记录模式是个好选择。当然他也存在问题,同样地,它对于复杂的业务上,维护的成本也很高,并且如果需求变更导致数据库修改,就需要调整记录对象模型中的相关代码。

经典应用:LINQ-TO-SQL以及Castle ActiveRecord。

领域模型模式是从领域驱动设计中衍生来的,它是以业务为核心的设计模式。它对于复杂的业务逻辑,相当适用。前三种方式使用的是以数据驱动方式,数据驱动方式特点简单,但是当系统到了一定的规模后,就会到难以维护的程度。

image

数据访问层的目的很明确,主要作为提供数据持久化的功能,包括数据的读取和写入,另外还必须包括事务处理,并发控制等等。

操作数据库的方法可以有两种方式,ORM方式,ADO.NET方式。

ORM可以采用一些第三方的ORM框架来实现,ADO.NET采用ASP.NET自带的数据库操作来实现。

不同的数据库具有不同的持久化实现,因此这里添加一个存储仓库接口层,来适应不同的数据库实现,这里你可以使用IOC依赖注入方式进行数据库选型,可以利用Unity、Spring.NET、Castle的IOC容器等等。

image

最后各个层中都可以依赖于公共基础设施层。

公共基础设施层可以包括Common通用模块,Logging日志模块,Exception异常模块,Configuration配置模块,DI依赖注入模块,单元测试模块以及第三方组件(例如NHibernate、Sprint.NET、Castle、Quartz计划任务等等)

最终图:

image

总结:项目类型、项目规模以及业务上的需求,都影响着系统架构的设计,系统架构并不是一层不变的,没有最好的架构,只有更好的架构,并且从项目中多思考系统的扩展性。文中对于架构的分析,只是从通常的角度上去考虑,在项目中,您还需要根据实际情况去做调整。

分享到:
评论

相关推荐

    (完整版)Java系统架构师面试题 (2).docx

    Java系统架构师面试题整理 本文总结了Java系统架构师面试题,涵盖了OOP、IOC、AOP、J2EE框架、SOA、ROA、JVM、Java通讯、软件架构、服务器、中间件、WEB服务器、权限分派、负载平衡、数据库设计、项目管理、团队...

    大话企业级android开发

    在企业级Android开发中,开发者需要面对的不仅仅是基础的编程技术,还需要掌握一系列高级技术和实践,以确保应用程序的稳定、高效以及与企业系统的无缝集成。本文将深入探讨UI组件、数据库管理和事务处理等方面的...

    电子书店管理系统Java 源码

    Java以其“一次编写,到处运行”的特性,广泛应用于企业级应用开发,尤其在Web服务和分布式系统中。在这个电子书店管理系统中,Java主要负责业务逻辑处理、用户交互以及与数据库的交互。例如,使用Servlet和JSP来...

    基于springboot微信小程序养老院系统源码数据库文档.zip

    这些信息有助于开发者理解数据如何存储和处理,对于系统维护和优化至关重要。 综上所述,这个项目涉及了后端开发、前端小程序开发和数据库设计等多个方面。开发者需要熟悉SpringBoot的微服务架构,Java编程,以及...

    谈谈软件学院高年级同学的学习方向(同济大学 JacksonWan)

    1. **编程语言**:Java和Python是企业级应用开发的常用语言,掌握其语法、面向对象编程思想以及相关的框架如Spring和Django至关重要。 2. **数据库管理**:理解SQL,熟悉Oracle、MySQL等数据库系统的操作和设计,...

    谈谈软件开发的那些事儿

    从早期的小型系统到如今的大型企业级应用,开发过程的复杂性显著增加。软件开发的轮回体现在从简单的程序设计到复杂的系统架构,再到跨平台、跨领域的集成。 1. 软件开发的轮回:早期的软件开发往往由少数开发者在...

    Spring+Struts+Hibernate 丽星私立管帐系统

    这部分内容对于理解和运行系统至关重要,因为它定义了数据的存储方式以及与Java对象的对应关系。 总的来说,“丽星私立管帐系统”通过Spring、Struts和Hibernate的集成,实现了业务逻辑、用户交互和数据持久化的...

    学生社团管理系统

    由“JAVA”标签可知,这个系统是用Java语言开发的,Java以其跨平台性、稳定性和丰富的类库成为开发企业级应用的首选语言。具体可能使用了Spring Boot框架,它简化了Java应用的初始搭建以及开发过程,同时集成了...

    邮箱系统 .net浪潮培训项目

    总的来说,这个“邮箱系统 .NET 浪潮培训项目”涵盖了.NET框架的运用、三层架构设计的实践以及存储过程的集成,对于想要深入学习.NET开发,特别是想了解如何构建复杂企业级应用的开发者来说,是一份宝贵的学习资源。...

    家庭理财系统(java+applet).rar

    SSH是Spring、Struts和Hibernate三个开源框架的组合,广泛应用于企业级Java Web开发。Spring作为核心容器,负责管理对象的生命周期和依赖注入;Struts则是一个用于构建MVC模式的Web应用框架;Hibernate是一个优秀的...

    Java毕业设计-基于springboot开发的大学生入学审核系统设计与实现-毕业论文(附毕设源代码).rar

    作为一款广泛应用于企业级应用开发的编程语言,Java以其跨平台、稳定性和强大的类库支持而闻名。在这个项目中,Java被用作主要的后端开发语言,用于编写业务逻辑和数据处理。它的面向对象特性使得代码结构清晰,易于...

    虚拟股票交易系统

    虚拟股票交易系统是一种模拟真实股票市场的在线平台,它允许用户以虚拟货币进行股票买卖操作,...通过这个项目,开发者不仅可以深入理解MVC架构,还能掌握企业级应用中的服务治理、数据库操作和事务处理等关键技能。

    房地产网站C#工厂模式

    在IT行业中,C#是一种广泛使用的编程语言,尤其在开发企业级应用,如房地产网站时。本项目以“房地产网站C#工厂模式”为主题,涵盖了C#编程、设计模式以及软件架构的重要概念。 首先,我们要了解**工厂模式**。这是...

    来访管理系统 免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程.zip

    随着信息技术的飞速发展,Java语言因其跨平台、面向对象和安全性能强的特点,在企业级应用中占据重要地位。特别是在Web应用开发领域,Java与Vue.js、SpringBoot等技术的结合,使得开发效率大幅提升,系统的稳定性...

    asp企业后台模板,我认为是一个很值得下的网站

    综上所述,ASP企业后台模板是Web开发领域的一个实用工具,它结合了ASP技术的强大功能和预设计的后台架构,为快速构建高效、稳定的企业级网站提供了捷径。无论你是经验丰富的开发者还是正在学习的新人,掌握这类模板...

    基于springboot的交流互动系统(1)源代码(java+vue+mysql+说明文档+LW).zip

    这有助于理解整个系统的架构和功能。另外,“java项目部署说明文档.zip”则包含了将该项目部署到服务器上的详细步骤和注意事项,这是非常关键的部分,因为一个项目即使开发完成,如果不能顺利部署到生产环境,那么它...

    基于ssm+vue图书管理系统.zip

    本文将深入探讨一个基于SSM(Spring、SpringMVC、MyBatis)和Vue.js技术栈的图书管理系统,这是一套常见的企业级开发方案,尤其适用于毕业设计或项目实践。 首先,我们来了解一下SSM框架。SSM是Java后端开发的主流...

Global site tag (gtag.js) - Google Analytics