.Net普通三层->工厂模式->线程内唯一+单元工作模式->WebService分布式三层

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq1010885678/article/details/38023225 在...
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq1010885678/article/details/38023225

在软件世界分层的思想无处不在

主要是为了提高软件系统的维护性,扩展性,复用性和解耦等

软件的三层构架是一种最基本的分层思想的体现

结构图大体如下:


如此一来,开发人员可以只关注其中一层,而无需关心下一层是如何实现的

但是最基本的三层构架在软件系统中很明显是不够用的

因为它带来优点的同时也带着许多缺点,比如耦合性高,经常出现修改某一层的代码另外一层也要随之大幅度整顿

而且当需求发生改变的时候,如:原先开发的时候使用mssql数据库,而现在又要求更换成mysql数据库

更换Dal层会导致Bll层也要重新设计

这时便可以使用工厂模式的三层

基本构架如下:


其实就是Bll和Dal层的代码分别实现他们接口层的接口

这体现了软件设计的针对接口编程的原则

为什么需要多出接口层实现呢

如,只要实现了IDAL层的接口

无论是mssql的Dal还是mysql的Dal层都可以随意的替换

通过一个工厂类来提供IDAL接口层的实体对象

Bll层中就只需要调用IDAL接口层中的方法就可以了而无需关心是谁实现的,怎么实现的

这时候如果要更换数据库所要修改的代码就大幅度减少了

只需要修改工厂类中相关的代码就可以,Bll层基本无需改动

但是这还是会修改代码

违反了软件设计原则中对扩展开发,对修改封闭的原则(开放-封闭原则)

我们可以利用反射技术来解决这个问题

我们可以再配置文件中配置好IDAL层中接口和Dal层中数据操作类所在的程序集名和所在的命名空间

在工厂类中根据配置文件中的信息利用反射动态创建Dal层的实体对象并转成IDAL中的接口

然后提供给Bll层使用

现在如果要更换数据库只需要更改配置文件中对应的程序集和命名空间信息就搞定,代码不需修改一行

(更绝的是,可以将配置信息放入数据库中,然后提供一个配置页面进行切换配置信息操作,这样一来连配置文件都不需要修改!)

上图中


因为各个实体类的CRUD方法都是差不多的,因此抽象出一个IBaseDal接口规定了CRUD的方法,并让IDAL层的所有接口都继承于这个基接口

同样对于Dal层的数据操作类,抽象出一个BaseDal基类,实现了IBaseDal中规定的CRUD基本方法,再次实现了代码复用


但是在很多的应用场景(如Web网站)

由于用户量大,可能导致很多问题,如数据不同步等多线程问题

可以采用线程内唯一的方案来对此问题进行改善

线程内唯一就是保证一个用户请求,访问的过程中只通过一个数据上下文进行操作,这样就不会出现因为缓存等情况而出现的数据混乱



上图在工厂模式的三层构架基础上添加了几个关键点:

1.在数据访问驱动之上设置了一个DbContextFactory工厂类,在此工厂类的内部通过CallContext方法从数据槽中取得唯一的数据访问驱动上下文

2.在IDAL接口层之上增设了DalContext层,该层是为了给Bll层一个调用IDAL接口的统一入口,但是其更重要的一个功能是通过一个公有的SaveChanges方法实现单元工作

3.和数据访问驱动层一样,在IDAL统一入口处设置了一个DalContextFactory工厂类来确保这个入口是线程内唯一的

那么什么是单元工作

比如在一个业务需求中

要对Users表进行添加

对Roles表进行删除

然后对Users和Roles的中间表进行修改

那么在此程序就会与数据库交互三次

但是如果是将三个操作线放入一个缓存中,等到最后一起提交到数据库

这样一来就减少了数据库的交互次数,提高了数据库的吞吐量

这就是单元工作模式

在EF中可以轻易的实现这个功能(在数据操作类中最后一步不要使用数据上下文的SaveChange保存操作,而是将其封装到DalContext中,使得Bll层可以在执行一系列的业务操作之后调用DalContext的SaveChanges方法进行统一的保存修改)

使用ADO.NET的话大致的思路就是将要执行的sql语句放入一个缓存队列中

通过另外一个工作进程通过轮询的方式(每隔一段时间,这个时间段间隔是非常小的)从缓存队列中取出sql语句一起提交到数据库


最后就是分布式的三层架构


我们可以通过WebService来比较简单的实现这一构架
在每层的WebService中通过该层的基本服务(简单三层,工厂三层或者线程内唯一+单元工作的三层等)
得到对应的接口
并通过这些接口的方法来接收和处理上一层发送的请求

相关文章
|
2月前
|
SQL 数据建模 BI
【YashanDB 知识库】用 yasldr 配置 Bulkload 模式作单线程迁移 300G 的业务数据到分布式数据库,迁移任务频繁出错
问题描述 详细版本:YashanDB Server Enterprise Edition Release 23.2.4.100 x86_64 6db1237 影响范围: 离线数据迁移场景,影响业务数据入库。 外场将部分 NewCIS 的报表业务放到分布式数据库,验证 SQL 性能水平。 操作系统环境配置: 125G 内存 32C CPU 2T 的 HDD 磁盘 问题出现的步骤/操作: 1、部署崖山分布式数据库 1mm 1cn 3dn 单线启动 yasldr 数据迁移任务,设置 32 线程的 bulk load 模式 2、观察 yasldr.log 是否出现如下错
|
4月前
|
存储 NoSQL MongoDB
.NET MongoDB数据仓储和工作单元模式封装
.NET MongoDB数据仓储和工作单元模式封装
71 15
|
8月前
|
数据库 开发者
.NET 异步编程之谜:async/await 模式究竟隐藏着怎样的神奇力量?
【8月更文挑战第28天】在当今注重效率和响应性的软件开发领域,.NET 的 async/await 模式如同得力助手,简化异步代码编写,使代码更易理解和维护。通过后台执行耗时操作,如网络请求和数据库查询,避免阻塞主线程,显著提升系统响应性。此模式不仅适用于网络请求,还广泛应用于数据库操作和文件读写。合理使用 async/await 可大幅优化性能,但需注意避免过度使用、正确处理调用链及异常,以确保系统稳定性和高效性。深入探索 async/await,助您构建更出色的应用程序。
78 0
|
4月前
|
开发框架 监控 .NET
C#进阶-ASP.NET WebForms调用ASMX的WebService接口
通过本文的介绍,希望您能深入理解并掌握ASP.NET WebForms中调用ASMX WebService接口的方法和技巧,并在实际项目中灵活运用这些技术,提高开发效率和应用性能。
166 5
|
5月前
|
开发框架 Java .NET
.net core 非阻塞的异步编程 及 线程调度过程
【11月更文挑战第12天】本文介绍了.NET Core中的非阻塞异步编程,包括其基本概念、实现方式及应用示例。通过`async`和`await`关键字,程序可在等待I/O操作时保持线程不被阻塞,提高性能。文章还详细说明了异步方法的基础示例、线程调度过程、延续任务机制、同步上下文的作用以及如何使用`Task.WhenAll`和`Task.WhenAny`处理多个异步任务的并发执行。
|
6月前
|
网络协议 大数据 网络架构
桥接模式和NET模式的区别
桥接模式和NET模式的区别
110 0
|
7月前
|
开发框架 NoSQL .NET
利用分布式锁在ASP.NET Core中实现防抖
【9月更文挑战第5天】在 ASP.NET Core 中,可通过分布式锁实现防抖功能,仅处理连续相同请求中的首个请求,其余请求返回 204 No Content,直至锁释放。具体步骤包括:安装分布式锁库如 `StackExchange.Redis`;创建分布式锁服务接口及其实现;构建防抖中间件;并在 `Startup.cs` 中注册相关服务和中间件。这一机制有效避免了短时间内重复操作的问题。
167 4
|
8月前
|
敏捷开发 设计模式 开发者
【揭秘终极利器】AgileEAS.NET:服务定位器模式的魔法,如何让企业级软件开发瞬间提速?揭秘背后的技术奥秘与实战指南!
【8月更文挑战第16天】AgileEAS.NET是基于DotNet的企业级敏捷开发平台,其服务定位器模式助力构建高度解耦系统。通过全局服务目录动态查找服务,避免硬编码依赖。在AgileEAS.NET中,服务定位器以静态类形式封装服务注册与检索功能。示例展示了如何注册与获取服务实例,如在`UserController`中通过服务定位器使用`IUserService`。此模式整合到框架生命周期管理,便于各处获取服务实例,提升开发效率。然而,应适度使用并考虑依赖注入容器以增强代码可维护性和可测试性。
110 4
|
8月前
|
开发框架 监控 .NET