Peasy.NET学习之并发问题处理
Peasy.net之并发处理
BusinessServiceBase是ServiceBase的自定义实现,提供了额外的独特功能
首先,创建一个业务服务,该业务服务必须继承BusinessServiceBase,同时要履行三个合同义务:
1,创建一个DTO,你的DTO将定义一个需要被指定为TKey通用参数的ID属性。可以让你的DTO实现IVersionContainer来参与并发处理。
2,创建一个数据代理实现IServiceDataProxy<T, TKey>,或通过创建从一个继承的数据代理这些类。
3,创建一个继承BusinessServiceBase的类,分别指定DTO(T)和ID(TKey),作为泛型类型参数,并要求数据代理作为构造函数参数,并将其传递给基类构造函数
例如,
public class BusinessServiceBaseMock : BusinessServiceBase<Person, long> //公共类
{
public BusinessServiceBaseMock(IServiceDataProxy<Person, long> dataProxy) : base(dataProxy) //base是基类,这表示把构造函数的参数传递给基类构造函数,
{
}
}
IServiceDataProxy<Person, long>必须将必需的构造函数参数传递给BusinessServiceBase的构造函数。
并发处理:
并发处理确保对数据存储的更新不会破坏其他用户所做的更改。BusinessServiceBase通过first-write-wins方案支持并发处理。
通过创建BusinessServiceBase的具体实现并使依赖的DTO实现IVersionContainer,可以轻松地实现并发处理。 //这是官方解释,其实不太理解
事实上,是这样的,在声明的抽象类中

这是他的具体继承实现类

这个Person里面就继承实现了IVersionContainer

IVersionContainer接口里面声明了Version

BusinessServiceBase将分别覆盖ServiceBase.Update和ServiceBase.UpdateAsync,分别在这里和这里提供它自己的实现。这些方法检查提供的DTO是否实现IVersionContainer接口。如果确实如此,则会将该Version值与数据存储中当前的值进行比较。如果版本不同,BusinessServiceBase将引发ConcurrencyException,否则会允许执行流程继续。
BusinessServiceBase抽象类里面重写了Update方法和UpdateAsync方法



这两个方法检查了DTO实体对象是否实现了接口IVersionContainer,如果确实如此,则会将该Version值与数据存储中当前的值进行比较。如果版本不同,BusinessServiceBase将引发ConcurrencyException,否则会允许执行流程继续。

需要注意的是注入到BusinessServiceBase实例中的数据代理必须处理DTO的更新和检索。Version属性可以使并发正常工作。
当你的服务类暴露DTO时,他们可能会泄露很多不应该是可更新的数据。例如,创建和更新日期等时间戳记字段。这些字段虽然对客户有用,但不一定可以由客户更新。状态是另一个很好的例子,因为您可能不希望客户更改这些值,而是希望以自己的工作流或类似形式呈现自己的业务逻辑。
BusinessServiceBase提供了禁止更改DTO某些字段的选择退出支持。这可以通过将System.ComponentModel.DataAnnotations.Editable属性应用于您要在更新过程中选择退出的DTO中的任何属性轻松实现。
BusinessServiceBase将分别覆盖ServiceBase.Update和ServiceBase.UpdateAsync,分别在这里和这里提供它自己的实现。这些方法首先从数据存储中查询当前的DTO表示,扫描所提供的DTO参数以查找与该Editable(false)属性一起应用的任何属性,然后将每个属性值恢复为其在数据存储中的当前状态。

将可空的外键属性从0恢复为NULL
在大多数数据库中,由于外键约束,外键值不能为零。由于您有时无法控制客户在处理您的DTO时所做的工作,因此假设客户将无意中修改了DTO的某些数据值,这是一个好主意。
没有指向手指,那里有很多控制工具包,这些工具包往往不能很好的处理空值。这些控件通常喜欢将空值,设置为0,当这些执行后的DTO到达您的执行流水线并且是时候将DTO保存在数据存储中时,您只有外键异常期待。
为了防止发生这种情况,您可以使用PeasyForeignKeyAttribute在您的DTO上应用可空的外键属性。将此属性应用于DTO上的可空的外键属性将确保它们总是在它们包含0值时恢复为空值。

可以为空的外键ForeingKeyID与PeasyForeignKey属性一起使用,因此将null在他们包含0在更新期间时设置他们。
PeasyForeignKey其实是这么定义的

Peasy.NET学习之并发问题处理的更多相关文章
- 如何才能够系统地学习Java并发技术?
微信公众号[Java技术江湖]一位阿里Java工程师的技术小站 Java并发编程一直是Java程序员必须懂但又是很难懂的技术内容. 这里不仅仅是指使用简单的多线程编程,或者使用juc的某个类.当然这些 ...
- 从源码学习Java并发的锁是怎么维护内部线程队列的
从源码学习Java并发的锁是怎么维护内部线程队列的 在上一篇文章中,凯哥对同步组件基础框架- AbstractQueuedSynchronizer(AQS)做了大概的介绍.我们知道AQS能够通过内置的 ...
- 如何深入学习Java并发编程?
在讲解深入学习Java并发编程的方法之前,先分析如下若干错误的观点和学习方法. 错误观点1:学习Java编程主要是学习多线程. 这话其实是说明了表面现象,多线程其实还真是并发编程的实现方式,但在实际高 ...
- 《Effective Java》 学习笔记 —— 并发
<Effective Java>第二版学习笔记之并发编程. 第66条 同步访问共享的可变数据 * 关键字synchronized可以保证在同一时刻只有一个线程可以执行某个方法或代码块. * ...
- JMeter学习笔记--并发登录测试
账号密码读取文件 1.设置线程数为30,并发用户量就是30个用户同时登录 2.添加同步定时器 添加 Synchronizing Timer 同步定时器,为了阻塞线程,当线程数达到指定数量,再同时释放, ...
- 通过 SingleFlight 模式学习 Go 并发编程
最近接触到微服务框架go-zero,翻看了整个框架代码,发现结构清晰.代码简洁,所以决定阅读源码学习下,本次阅读的源码位于core/syncx/singleflight.go. 在go-zero中Si ...
- Java多线程学习(一)---并发与多线程
Java并发与多线程 摘要: 1. 并发与并行的区别,何为并发编程,并发编程的优势在哪 2. 多线程.多任务.多进程机制概述 3. 多线程.多任务.多进程机制与编程思想的关系 一.并发 1.1 并发与 ...
- [javaSE] 看博客学习java并发编程
共享性 多线程操作同一个数据,产生线程安全问题 新建一个类ShareData 设计一个int 型的成员变量count 设计一个成员方法addCount(),把count变量++ 在main函数中开启多 ...
- 学习Java并发的课程
https://www.javaspecialists.eu/courses/concurrency.jsp http://www.jconcurrent.com/ javaConcurrentAni ...
随机推荐
- python 数据压缩
zlib 压缩 import zlib import this s = this.s.encode('utf8')*10 for i in range(10): data = zlib.compres ...
- [BJWC2018]上学路线
Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路口.小B ...
- BUUCTF RE部分题目wp
RE 1,easyre拖进ida,得到flag 2,helloworld 将文件拖入apk改之理,得到flag 3,xor拖进ida,就是简单异或,写脚本 glo=[0x66,0x0a,0x6b,0x ...
- Codeforces New Year and Arbitrary Arrangement
New Year and Arbitrary Arrangement time limit per test2 seconds You are given three integers k, pa a ...
- linux基础文件管理软硬链接
一.文件系统的基本结构 1.文件和目录被组成一个单根倒置树目录结构 2.文件系统从根目录下开始,用“/”表示 3.根文件系统(rootfs):root filesystem文件名区分大小写 4.以 . ...
- Final 可重入锁 安全发布
无状态对象(既不包含任何域,也不包含任何其他类中域的引用)一定是线程安全的. Final fianl域是不能修改的(但如果final域所引用的对象是可变的,那么这些被引用的对象是可变的) 除非需要可变 ...
- Java实体与Json操作类
import com.fasterxml.jackson.core.JsonProcessingException; import com.fasterxml.jackson.databind.Jav ...
- AcWing 144. 最长异或值路径 01字典树打卡
给定一个树,树上的边都具有权值. 树中一条路径的异或长度被定义为路径上所有边的权值的异或和: ⊕ 为异或符号. 给定上述的具有n个节点的树,你能找到异或长度最大的路径吗? 输入格式 第一行包含整数n, ...
- jQuery Validate (1)
一.用前必备官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-validation/ API: http://jquery.bassist ...
- RabbitMQ 交换器、持久化
一. 交换器 RabbitMQ交换器(Exchange)分为四种 direct fanout topic headers direct 默认的交换器类型,消息的RoutingKey与队列的bindi ...