热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

将不确定变为确定~transactionscope何时提升为分布式事务~再续(避免引起不必要的MSDTC)...

相关文章将不确定变为确定~transactionscope何时提升为分布式事务将不确定变为确定~transactionscope何时提升为分布式事务~续将不确定变为确定~trans

相关文章

将不确定变为确定~transactionscope何时提升为分布式事务

将不确定变为确定~transactionscope何时提升为分布式事务~续      

将不确定变为确定~transactionscope何时提升为分布式事务~再续(避免引起不必要的MSDTC)


 

       对于transactionscope我在之前写过两篇文件,在上一篇文章中已经把它何时会触发分布式事务写的很清楚了,但实现上,对于原理上为何会产生MSDTC说的还不够明白,所以,有必要再写一篇终如何去避免不必要的MSDTC。

注意本篇文章是上一篇文章的继续,主要说的是数据库服务器与WWW服务器不在同一台电脑上的情况

前言

分布式事务它依赖于windows的一个服务MSDTC,只有WWW服务器上的MSDTC服务处于启动状态,我们才可以使用分布式事务,对于分布式事务官方这样定义它:协调跨多个数据库、消息队列、文件系统等资源管理器的事务。

frameworks什么时候会认识我们的TransactionScope是分布式的

对于数据库多表操作来说,它何时是分布式,要看你的事务中的connection会话的数量,如果是一次,它会认识你在操作一个数据库,这当然不会引入MSDTC,但如果你是多个connection会话,它会认识你在操作多张表,这时它属于分布式的范畴,同时会引起MSDTC。

为什么我们在项目中,对于操作同一个数据库的多张表,总会产生MSDTC

这要看一个基础问题,事实很多时候解决问题的方法都是从基础知识入手了,你之所以会犯错是因为你对基础知识掌握不牢靠。

对于LINQ To SQL或者EF等ORM来说,它们会提供一个SubmitChanges,作用是打开connection,将操作内容提交到数据库,关闭connection。

而我们为了代码的精简性,有时会有CURD操作进行封装,这是正常的,为了维护代码方便进行必要的封装,是种面向对象的思想,但注意,当你insert操作之后,如果封装了SubmitChange,这时系统会认识你是一次完成的connection动作,而在进行第二个insert操作时,这时,会有两个connection会话了,而在TransactionScope范围内,对于多个Connection的理解就是多个库,所以系统肯定会把它提升为分布式事务,并启用MSDTC去支持它,这是正常的,一切都很正常,而对于我们来说,不希望每个TransactionScope都产生MSDTC,所以,我们应该如何去应对,方法很容易,将CURD操作的方法进行重装,加个参数isSubmit就可以了,代码如下:

///

/// 插入操作/// /// 实体类型/// 实体/// 是否同时提交到数据库,对于写在transactionscope里的多条语句,/// 如果本语句不是最后一条,本值为false,即不立即提交到数据public void Insert(TEntity entity, bool isSubmit) where TEntity : class{if (entity is EntityBase)(entity as EntityBase).OnInsertBefore();//Logger.InfoLog("Create 表名:{0},内容:{1}", entity, ToJson(entity));_db.Entry(entity);_db.Set().Add(entity);if (isSubmit) this.SaveChanges();if (entity is EntityBase)(entity as EntityBase).OnInsertAfter();}

对于具体的事务块,代码可能是这样:

using (TransactionScope trans = new TransactionScope()){try{base.Insert(entity.Product_Comment, false);base.Insert(entity.Review);trans.Complete();}catch (Exception){throw;}finally{trans.Dispose();}}

对于一个SubmitChange()所产生的SQL代码为:(一个connection会话)

对于多个SubmitChange()所产生的SQL代码为:(多个connection会话)

总结:对于数据服务器与WWW服务器不在一起电脑上时,产生MSDTC的关键在于connection会话的数据,一个会话表示操作一个数据库,这时不产生MSDTC,如果多个会话,认识是操作多个数据库,所以就产生了MSTDC!小微真聪明!

感谢阅读!

本文转自博客园张占岭(仓储大叔)的博客,原文链接:将不确定变为确定~transactionscope何时提升为分布式事务~再续(避免引起不必要的MSDTC),如需转载请自行联系原博主。



推荐阅读
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 解决.net项目中未注册“microsoft.ACE.oledb.12.0”提供程序的方法
    在开发.net项目中,通过microsoft.ACE.oledb读取excel文件信息时,报错“未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序”。本文提供了解决这个问题的方法,包括错误描述和代码示例。通过注册提供程序和修改连接字符串,可以成功读取excel文件信息。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 重入锁(ReentrantLock)学习及实现原理
    本文介绍了重入锁(ReentrantLock)的学习及实现原理。在学习synchronized的基础上,重入锁提供了更多的灵活性和功能。文章详细介绍了重入锁的特性、使用方法和实现原理,并提供了类图和测试代码供读者参考。重入锁支持重入和公平与非公平两种实现方式,通过对比和分析,读者可以更好地理解和应用重入锁。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
author-avatar
小丽丽很可爱
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有