软件的三层架构

软件的三层架构

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

全然看不懂

基于软件三层架构的研究报告

引言

三层结构是传统的客户/server结构的发展,代表了企业级应用的未来,典型的有Web下的应用。多层结构和三层结构的含义是一样的,仅仅是细节有所不同。之所以会有双层、三层这些提法,是由于应用程序要解决三个层面的问题。

一、  软件架构和分层

(一)  软件架构(software architecture)

是一系列相关的抽象模式,用于指导大型软件系统各个方面的设计。 软件架构是一个系统的草图。软件架构描写叙述的对象是直接构成系统的抽象组件。各个组件之间的连接则明白和相对仔细地描写叙述组件之间的通讯。在实现阶段,这些抽象组件被细化为实际的组件,比方详细某个类或者对象。在面向对象领域中,组件之间的连接通经常使用接口(计算机科学)来实现。 软件体系结构是构建计算机软件实践的基础。与建筑师设定建筑项目的设计原则和目标,作为绘图员绘图的基础一样,一个软件架构师或者系统架构师陈述软件构架以作为满足不同客户需求的实际系统设计方案的基础。

(二)分层

分层是表示将功能进行有序的分组:应用程序专用功能位于上层,跨越应用程序领域的功能位于中层,而配置环境专用功能位于低层。分层从逻辑上将子系统划分成很多集合,而层间关系的形成要遵循一定的规则。通过分层,能够限制子系统间的依赖关系,使系统以更松散的方式耦合,从而更易于维护。子系统的分组标准包括下面几条规则可见度。各子系统仅仅能与同一层及其下一层的子系统存在依赖关系。

(三)使用分层架构开发的必要性

    1、分层设计同意你切割功能进入不同区域。换句话说层在设计是就是逻辑组件的分组。比如,A层能够訪问B层,但B层不能訪问A 层。

    2、用分层的方法,以提高应用程序的可维护性,并使其更easy扩展,以提高性能。

(四)设计分层的原则

1、层意味着组建的逻辑分组。比如,对用户界面,业务逻辑和数据訪问组建应该使用不同的不同的层。

2、在一个层内组建应该聚合的。如业务层组建仅应提供与业务逻辑相关的操作,而不是提供其它操作。

3、在设计的每个层接口时要考虑好物理边界。假设通信扩月了物理边界,使用基于消息操作;否则使用基于对象操作。

4、考虑使用接口类型(interface)来定义每层的接口。这将同意你创建该接口的不同实现,提高可測性。

5、对于Web应用程序,在表示层和业务逻辑层之间实现基于消息的接口是一个好主意,即使这两层没有跨越物理边界。基于消息的接口更适合于无状态的Web操作。

二、软件的三层架构

(一)概述

在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据訪问层、业务逻辑层(又或称为领域层)、表示层。

1、表示层(UI):通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。   

2、业务逻辑层(BLL):针对详细问题的操作,也能够说是对数据层的操作,对数据业务逻辑处理。   

3、数据訪问层(DAL):该层所做事务直接操作数据库,针对数据的增添、删除、改动、查找等。

  

(二)三层结构原理:   

 

3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。   

所谓三层体系结构,是在client与数据库之间增加了一个“中间层”,也叫组件层。这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不唯独B/S应用才是三层体系结构,三层是指逻辑上的三层,即使这三个层放置到一台机器上。三层体系的应用程序将业务规则、数据訪问、合法性校验等工作放到了中间层进行处理。通常情况下,client不直接与数据库进行交互,而是通过COM/DCOM通讯与中间层建立连接,再经由中间层与数据库进行交互。

   

(三)各层的作用

 

数据訪问层:

有时候也称为是持久层,其功能主要是负责数据库的訪问,能够訪问数据库系统、二进制文件、文本文档或是XML文档。简单的说法就是实现对数据表的Select,Insert,Update,Delete的操作。假设要增加ORM的元素,那么就会包含对象和数据表之间的mapping,以及对象实体的持久化。主要是对原始数据(数据库或者文本文件等存放数据的形式)的操作层,而不是指原始数据,也就是说,是对数据的操作,而不是数据库,详细为业务逻辑层或表示层提供数据服务。

   

业务逻辑层:

主要是针对详细的问题的操作,也能够理解成对数据层的操作,对数据业务逻辑处理,假设说数据层是积木,那逻辑层就是对这些积木的搭建。业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,非常多时候,也将业务逻辑层称为领域层。比如Martin Fowler在《Patternsof Enterprise Application Architecture》一书中,将整个架构分为三个基本的层:表示层、领域层和数据源层。作为领域驱动设计的先驱Eric Evans,对业务逻辑层作了更仔细地划分,细分为应用层与领域层,通过分层进一步将领域逻辑与领域逻辑的解决方式分离。   业务逻辑层在体系架构中的位置非常关键,它处于数据訪问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有不论什么影响。假设在分层设计时,遵循了面向接口设计的思想,那么这样的向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正由于如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,由于它扮演了两个不同的角色。对于数据訪问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,怎样实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务。   

 

表示层:

位于最外层(最上层),离用户近期。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。主要表示WEB方式,也能够表示成WINFORM方式,WEB方式也能够表现成:aspx, 假设逻辑层相当强大和完好,不管表现层怎样定义和更改,逻辑层都能完好地提供服务。

   

(四)详细调用

 

微软的DNA架构定义了三个层:表示层(presentation),业务逻辑层(business),和数据訪问层(data access)。详细又分为:界面外观层、界面规则层、业务接口层、业务逻辑层、实体层、数据訪问层、数据存储层共七层,其详细的调用如图1所看到的:

 

(五)规则

    1.系统各层次及层内部子层次之间都不得跨层调用。
    2.Entityobject 在各个层之间传递数据。
    3.须要在UI层绑定到列表的数据採用基于关系的DataSet传递,除此之外,应该使用Entityobject传递数据。
    4.对于每个数据库表(Table)都有一个DB Entity class与之相应,针对每个Entityclass都会有一个BEM Class与之相应。
    5.有些跨数据库或跨表的操作(如复杂的联合查询)也须要由对应的BEM Class来提供支持。
    6.对于相对简单的系统,能够考虑将Business Function子层和Business Flow 子层合并为一个。
    7.UI层和BL层禁止出现不论什么SQL语句。

 

 

三、优缺点

(一)长处

1、开发者能够仅仅关注整个结构中的当中某一层;  

2、能够非常easy的用新的实现来替换原有层次的实现;  

3、能够减少层与层之间的依赖;   

4、有利于标准化;   

5、利于各层逻辑的复用。

(二)缺点

1、减少了系统的性能。这是不言而喻的。假设不採用分层式结构,非常多业务能够直接造訪数据库,以此获取对应的数据,现在却必须通过中间层来完毕。   

2、有时会导致级联的改动。这样的改动尤其体如今自上而下的方向。假设在表示层中须要添加一个功能,为保证其设计符合分层式结构,可能须要在对应的业务逻辑层和数据訪问层中都添加对应的代码。   

3、添加了开发成本。

 

(三)为什么要使用三层架构

对于一个简单的应用程序来说,代码量不是非常多的情况下,一层结构或二层结构开发全然够用,没有必要将其复杂化,假设对一个复杂的大型系统,设计为一层结构或二层结构开发,那么这种设计存在非常严重缺陷。以下会详细介绍,分层开发事实上是为大型系统服务的。在开发过程中,0基础程序人员出现相似的功能常常复制代码,那么相同的代码写那么多次,不但使程序变得冗长,更不利于维护,一个小小的改动也许会涉及非常多页面,常常导致异常的产生使程序不能正常执行。最基本的面向对象的思想没有得到丝毫的体现,打着面向对象的幌子却依旧走着面向过程的道路。意识到这种问题,0基础程序人员開始将程序中一些公用的处理程序写成公共方法,封装在类中,供其他程序调用。比如写一个数据操作类,对数据操作进行合理封装,在数据库操作过程中,仅仅要类中的对应方法(数据加入、改动、查询等)能够完毕特定的数据操作,这就是数据訪问层,不用每次操作数据库时都写那些反复性 的数据库操作代码。在新的应用开发中,数据訪问层能够直接拿来用。面向对象的三大特性之中的一个的封装性在这里得到了非常好的体现。如今找到了面向对象的感觉,代码量较曾经有了非常大的降低,并且改动的时候也比較方便,也实现了代码的重用性。

四、与MVC的差别

    MVC是三个单词的缩写,分别为:模型(Model),视图(View)和控制Controller) MVC模式的目的就是实现Web系统的职能分工。 Model层实现系统中的业务逻辑,通常能够用JavaBeanEJB来实现。 View层用于与用户的交互,通经常使用JSP来实现。 Controller层是ModelView之间沟通的桥梁,它能够分派用户的请求并选择恰当的视图以用于显示,同一时候它也能够解释用户的输入并将它们映射为模型层可运行的操作。

相同是架构级别的,相同的地方在于他们都有一个表现层,可是他们不同的地方在于其它的两个层。   

在三层架构中未定义Controller的概念。而MVC也没有把业务的逻辑訪问看成两个层,这是採用三层架构或MVC搭建程序最基本的差别。当然,在三层中也提到了Model,可是三层架构中Model的概念与MVC中Model的概念是不一样的,“三层”中典型的Model层是以实体类构成的,而MVC里,则是由业务逻辑与訪问数据组成的。

 

五、小结

在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。 所以,分层式设计能够达至例如以下目的:分散关注、松散耦合、逻辑复用、标准定义。一个好的分层式结构,能够使得开发者的分工更加明白。一旦定义好各层次之间的接口,负责不同逻辑设计的开发者就能够分散关注,齐头并进。尽管三层架构仍有不可避免的缺陷,可是软件分层结构使得代码维护很方便,设计明白,各层独立,专注自己擅长的领域。通过这次报告,对软件体系结构又有了更深入的了解。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118036.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 修改tomcat启动窗口名称_重启tomcat命令

    修改tomcat启动窗口名称_重启tomcat命令Tomcat bin目录下用startup.bat启动Tomcat ,启动窗口显示的Title 更改方法如下:1 在bin目录下找到catalina.bat ,用文本模式打开2 找到 if “%TITLE%” == “” set TITLE=Tomcat 这句3 把 set TITLE=Tomcat 更改为 set TITLE=(想使用的名称包括中文) 即可。如图:…

  • R语言怎么绘图(一个r语言完整的命令有什么)

    使用系统:centos6.464bit在R语言中可以使用png()等函数生成图片,例如:png(“aa.png”)可以生成图片。但是如果你是通过shell远程连接到系统上,可能会碰到如下错误:>png(“aa.png”)错误于.External2(C_X11,paste(“png::”,filename,sep=””),g$width,:无法打开PNG设备此外:警告…

  • 【Python 局域网控制】——做一个超简单的局域网指令控制电脑

    【Python 局域网控制】——做一个超简单的局域网指令控制电脑程序分为两部分,一个是客户端也是被操控的端口,另一个是服务端就是用来操作被操控的端口点个赞留个关注吧!!程序很简单,是通过局域网聊天系统改造而成,没有高级的GUI框架,只有简简单单的DOS窗口,这个仅供学习,当然也可以在你的第二台电脑里放入客户端,然后用服务端进行指令操作,也是很不错的。客户端会自动获取你的IPv4地址,并显示出来,需要用客户端给出的IP地址去服务端进行连接。执行指令也很简单,用接收到的数据进行os.system()进行执行。想法多的也可以做一个鼠标定位数据传输,可达到鼠

  • 英特尔CPU后缀「建议收藏」

    英特尔CPU后缀「建议收藏」X后缀X代表Extreme,中文意思是至尊级,代表同一时代性能最强的CPU。如Corei7-5960X、Corei7-4960X。X代表在同一代中只有一款CPU黄袍加身,地位至高无上。加上没有竞争对手可以望其项背,从露面都退出市场,期待的弑君者没有出现。SandyBridge时代到现在,竞争的天平一直向Intel倾斜。K后缀=解锁倍频且更高性能:自从SandyBridge时代Inte…

  • Pytest(6)重复运行用例pytest-repeat[通俗易懂]

    Pytest(6)重复运行用例pytest-repeat[通俗易懂]前言平常在做功能测试的时候,经常会遇到某个模块不稳定,偶然会出现一些bug,对于这种问题我们会针对此用例反复执行多次,最终复现出问题来。自动化运行用例时候,也会出现偶然的bug,可以针对单个用例,

  • 使用工具清理Windows的winsxs目录

    使用工具清理Windows的winsxs目录一、使用软件工具清理1、使用DriverStoreExplorer清理DriverStoreExplorer下载地址:https://github.com/lostindark/DriverStoreExplorer/releases/download/v0.11.64/DriverStoreExplorer.v0.11.64.zip使用方法:(1)双击运行(使用管理员)(2)点击“选取旧的驱动”,之后点击“删除驱动包”2、使用Winsxs清理工具笔者吐槽:这个软件提供的论坛我上去看

    2022年10月28日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号