走向ASP.NET架构设计-第六章-服务层设计(中篇)

简介:
走向ASP.NET 架构设计- 第六章- 服务层设计( 中篇)
  前言:上一篇文章介绍了一些服务层的基本知识,而且也简要的介绍了SOA 的有关知识,本篇主要是介绍在服务层可以采用的一些模式。 
本篇议题如下:
Façade  模式
Document Message Request-Reponse 模式
Reservation  模式
Idempotent 模式
   
  Façade 设计模式
  在SOA 客户端的设计中,最常用的模式就是Façade 模式了。Façade 模式简化了复杂子系统的调用接口,也就说,Façade 隐藏了子系统之间的复杂关系,给客户端一个简单的调用接口。 
   Façade 模式的好处如下:
1.  它可以使得第三方的类库经过包装之后,通过一个简单的接口就可以调用,如下图所示。
2.  它可以通过抽象等方式来解耦其他系统之间的依赖。
3.  它可以使得各个子系统之间的调用复杂度隐藏,通过一个简单的接口就可以调用,如下图所示
 
  在上面的图中:
1.  客户端调用Façade 的一个简单的API 来执行一个任务。客户端不知道Façade 内部是如何实现的,可能只一个任务的执行涉及到很多内部子系统的交互和合作。
2. SubSystemA SubSystemB 才是真正的任务执行者。
 
  下面我们就来看看客户端和服务层之间进行通信的一些模式。
  注:把这些模式讲完之后就讲一个如何使用这些模式的例子。 
 
  Document Message Request-Reponse 模式( 文档消息模式 请求- 响应模式)
在体会文档消息模式的好处之前,我们先来看看一种通信方式:RPC Remote Procedure Call  远程过程调用):RPC 方式通过暴露很多不同参数的API 来实现提供不同服务,如下:
 
Customer[] RetrieveCustomers( string  country);
Customer[] RetrieveCustomers (
string  country,  string  postalCode);
Customer[] RetrieveCustomers (
string  country,  string  postalCode,  string  street);
 
 
上面的服务接口允许客户端通过三种方式来获取用户的信息:通过提供不同的参数来实现。这种方式的维护很难的,而且往往把客户端搞糊涂,而且服务器端可能最后向客户端暴露很多名字一样的方法,尽管可以在WCF 中改变方法最后显示到客户端的名字,但是方法依然泛滥。
 
文档消息模式可以让客户端以统一和灵活的方式和服务进行通信。文档消息模式把客户端把所有的请求的信息包装成为一个信息体,发送给服务端,而且服务端的接口的定义也非常的简单,如下:
  
Customer[] FindBy(CustomerSearchRequest request);
 
这个消息体的定义如下:
 
public   class  CustomerSearchRequest
{
    
public   string  Country {  get set ; }
    
public   string  PostalCode {  get set ; }
    
public   string  Street {  get set ; }
}
 
 
有的时候消息体还携带其他额外的信息到服务端,如服务的版本号,验证授权标识等。当然了,这些额外的,相同的信息,我们可以定义一个请求消息的基本,然后让所有的请求消息都集成基类。
 
通过使用文档消息模式,我们就解决了之前RPC 的一些问题,当然服务端对消息要做一些处理的。
文档消息模式一般和请求- 响应模式一起使用。如之前的例子,我们是直接返回了Customer 的数组,其实有些时候可能不想把业务类的定义暴露出来,而且可能我们还要给客户端返回添加额外的信息,那么我们的服务端的接口定义如下:
 
CustomerSearchResponse RetrieveCustomers(CustomerSearchRequest request);
 
 
其实在之前的一些章节中的代码的例子,很多都演示了这样的模式的使用。
大家可以看看一般文档消息模式请求- 响应模式的图示:
 
 
 
  Reservation  模式( 预约保留模式)
一般情况下,SOA 中服务器那边都是无状态的,但是可能有些时候,我们需要服务器端来保存一个长时间运行的服务的一些状态,在这段时间内,客户端可能向服务器端发送很多的请求都被当成一个事务或者一个工作单元来处理。
 
Reservation 模式就是来解决这样的问题的:
1.  我们可以发送一个请求给服务器,从服务端响应中获取一个预约的唯一编号
2.  客户端余下的请求中都带上这个编号,以便服务器那边可以把这些请求当做一个事务处理来完成。
  通常情况下,这个预约的编号是有一定的期限的,也就说,一段时间之后,这个编号在服务端那边就过期了,主要是为了避免资源的耗费以及一些安全问题。 
  我们还是看看下面的一个在线订票系统中使用“Reservation  模式”的图示:
 
 
 
  在上图中:
1.  客户端首先调用ReserveTickets 服务方法,并且提供一些基本的信息给服务器:订阅2 张票等。
2.  服务端的响应就返回了一个预约的Id 和一个过期的时间。
3.  客户端程序执行一个逻辑。这些逻辑可能会从涉及到把获取customer 的详细信息作为订票一个处理过程,或者进行更多的复杂的客户端和服务端的交互。
4.  最后客户端把服务端需要的信息连同预约的Id 一同提交,调用PurchaseTicket 方法,然后服务端就返回订票成功的编号。
 
  可能上面的例子不是很恰当,大家明白其中的意思就行。
 
   Idempotent模式( 等幂模式
  在调用服务接口的时候,可能出现:用同样的参数来多次调用同一个服务接口,这种情况,但是可能是我们想要的,但是也可以不是我们想要的。例如,在订单系统中,由于某些原因,导致用户把同一个账单提交了多次(如,不小心点了多次提交按钮),那么系统中的数据就出问题。所以可以采用Idempotent 模式来确保相同的参数提交多次,但是服务端只是处理一次。 
  Idempotent 模式的基本思想是这样的:每一次的客户端的请求,都被赋予了一个唯一的请求标识(如,这个标识的生成规则可能是通过这个请求的一些参数做一些算法来生成)。在服务端就在一个存储区域检查这个唯一的标识时候已经被处理过了,是否有对应的响应信息,如果有,那么直接把响应信息返回;如果没有,那么处理这个请求。
  如下图所示:
 
 
  今天就写到这里,下一篇就开始利用WCF 来做一个Demo 了。 






















本文转自yanyangtian51CTO博客,原文链接:http://blog.51cto.com/yanyangtian/442638  ,如需转载请自行联系原作者


相关文章
|
存储 开发框架 前端开发
前端框架EXT.NET Dotnet 3.5开发的实验室信息管理系统(LIMS)成品源码 B/S架构
发展历史:实验室信息管理系统(LIMS),就是指通过计算机网络技术对实验的各种信息进行管理的计算机软、硬件系统。也就是将计算机网络技术与现代的管理思想有机结合,利用数据处理技术、海量数据存储技术、宽带传输网络技术、自动化仪器分析技术,来对实验室的信息管理和质量控制等进行全方位管理的计算机软、硬件系统,以满足实验室管理上的各种目标(计划、控制、执行)。
136 1
|
6月前
|
开发框架 前端开发 .NET
一个适用于 .NET 的开源整洁架构项目模板
一个适用于 .NET 的开源整洁架构项目模板
119 26
|
8月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
90 3
|
9月前
|
开发框架 .NET API
Windows Forms应用程序中集成一个ASP.NET API服务
Windows Forms应用程序中集成一个ASP.NET API服务
175 9
|
9月前
|
存储 消息中间件 前端开发
.NET常见的几种项目架构模式,你知道几种?
.NET常见的几种项目架构模式,你知道几种?
253 0
|
11月前
|
设计模式 存储 前端开发
揭秘.NET架构设计模式:如何构建坚不可摧的系统?掌握这些,让你的项目无懈可击!
【8月更文挑战第28天】在软件开发中,设计模式是解决常见问题的经典方案,助力构建可维护、可扩展的系统。本文探讨了.NET中三种关键架构设计模式:MVC、依赖注入与仓储模式,并提供了示例代码。MVC通过模型、视图和控制器分离关注点;依赖注入则通过外部管理组件依赖提升复用性和可测性;仓储模式则统一数据访问接口,分离数据逻辑与业务逻辑。掌握这些模式有助于开发者优化系统架构,提升软件质量。
139 5
|
11月前
|
XML 开发框架 .NET
.NET框架:软件开发领域的瑞士军刀,如何让初学者变身代码艺术家——从基础架构到独特优势,一篇不可错过的深度解读。
【8月更文挑战第28天】.NET框架是由微软推出的统一开发平台,支持多种编程语言,简化应用程序的开发与部署。其核心组件包括公共语言运行库(CLR)和类库(FCL)。CLR负责内存管理、线程管理和异常处理等任务,确保代码稳定运行;FCL则提供了丰富的类和接口,涵盖网络、数据访问、安全性等多个领域,提高开发效率。此外,.NET框架还支持跨语言互操作,允许开发者使用C#、VB.NET等语言编写代码并无缝集成。这一框架凭借其强大的功能和广泛的社区支持,已成为软件开发领域的重要工具,适合初学者深入学习以奠定职业生涯基础。
226 1
|
负载均衡 Java Linux
黑马头条01,环境搭建,今日头条的介绍,今日头条的功能架构图,技术栈的说明,服务层,nacos(奶靠丝)安装,安装在Linux服务器上环境准备,
黑马头条01,环境搭建,今日头条的介绍,今日头条的功能架构图,技术栈的说明,服务层,nacos(奶靠丝)安装,安装在Linux服务器上环境准备,
|
数据安全/隐私保护 Windows
.net三层架构开发步骤
.net三层架构开发步骤
|
开发框架 .NET 容器
.NET Core-依赖注入:良好架构的起点
.NET Core-依赖注入:良好架构的起点

热门文章

最新文章