声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。web
三层架构模式介绍
三层架构模式:
三层架构(3-tier architecture) 一般意义上的三层架构就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)。区分层次的目的即为了 “高内聚低耦合” 的思想。在软件体系架构设计中,分层式结构是最多见,也是最重要的一种结构。微软推荐的分层式结构通常分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。数据库
表示层:
界面层也称为表示层,位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操做的界面。编程
业务逻辑层:
业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也便是说它是与系统所应对的领域(Domain)逻辑有关,不少时候,也将业务逻辑层称为领域层。例如Martin Fowler在《Patterns of Enterprise Application Architecture》一书中,将整个架构分为三个主要的层:表示层、领域层和数据源层。做为领域驱动设计的先驱Eric Evans,对业务逻辑层做了更细致地划分,细分为应用层与领域层,经过分层进一步将领域逻辑与领域逻辑的解决方案分离。 业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的做用。因为层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。若是在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。于是在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正由于如此,业务逻辑层的设计对于一个支持可扩展的架构尤其关键,由于它扮演了两个不一样的角色。对于数据访问层而言,它是调用者;对于表示层而言,它倒是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑以外留给设计师的任务。json
数据访问层:
数据访问层,有时候也称为是持久层,其功能主要是负责数据库的访问,能够访问数据库系统、二进制文件、文本文档或是XML文档。简单的说法就是实现对数据表的select、insert、update以及delete的操做。若是要加入ORM的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化。小程序
三层与MVC的区别:
不少人容易把三层模式与MVC模式混淆,三层与MVC的最不一样的地方在于三层是没有Controller控制器的概念。虽然一样是架构级别的,三层与MVC相同的地方在于他们都有一个表现层,可是他们不一样的地方在于其余的两个层。MVC没有把业务的逻辑访问当作两个层,这是采用三层架构或MVC搭建程序最主要的区别。固然了,在三层中也提到了Model概念,可是三层架构中Model的概念与MVC中Model的概念是不同的,“三层” 中典型的Model层是以实体类构成的,而MVC里,则是由业务逻辑与访问数据组成的。微信小程序
在三层中JSP与Servlet代码都属于表示层,业务逻辑层则是完成业务规则的实体类,数据访问层则是JDBC等代码,示意图:服务器
三层架构把不一样层的业务职责分离得更加完全,逻辑层不包含一丁点的视图层代码,一样的数据层也不该该包含一丁点的逻辑层代码,由于若是包含了其余层的代码就不能作到彻底解耦,依旧存在必定程度的耦合性。微信
三层架构更好的实现了模块化编程,使用三层架构设计的系统更容易扩展、更换,特别是现在不止pc端一种设备,若是没作好分层就没法适应多设备的访问。例如表示层咱们使用jsp+Servlet作的,面向的是web,若是哪天不作web了,要把整个表示层更换成桌面的图形化来显示,那么使用了三层架构的话,只须要更换表示层便可,逻辑层和数据层均可以进行复用。若是没有进行分层的话,各个模块都耦合在一块儿就没法进行复用,只能从新再编写一个适应桌面的系统出来,这样就很耗时耗力了。架构
咱们都知道WebService是一种跨编程语言和跨操做系统平台的远程调用技术,若是一个系统是使用三层架构进行设计的,那么逻辑层就能够经过WebService共享给其余不一样语言编写的应用程序调用。app
最近流行的微信小程序是经过https访问服务器的,它须要服务器返回json数据,那么咱们就能够在视图层中的Servlet接收这个访问,处理完成后返回json数据。
示意图:
三层开发模式的优缺点
优势:
一、开发人员能够只关注整个结构中的其中某一层;
二、能够很容易的用新的实现来替换原有层次的实现;
三、能够下降层与层之间的依赖;
四、有利于标准化;
五、利于各层逻辑的复用。
六、结构更加的明确
七、在后期维护的时候,极大地下降了维护成本和维护时间
缺点:
一、下降了系统的性能。这是不言而喻的。若是不采用分层式结构,不少业务能够直接造访数据库,以此获取相应的数据,现在却必须经过中间层来完成。
二、有时会致使级联的修改。这种修改尤为体如今自上而下的方向。若是在表示层中须要增长一个功能,为保证其设计符合分层式结构,可能须要在相应的业务逻辑层和数据访问层中都增长相应的代码。
好比,一家饭店添加了同样菜, 那个菜单(UI) , 厨师(BLL) , 采购(DAL) 都要进行相应的处理