肥宅钓鱼网
当前位置: 首页 钓鱼百科

数据库事务未提交(数据库事务管理)

时间:2023-07-19 作者: 小编 阅读量: 1 栏目名: 钓鱼百科

数据库事务管理无论是开发APP还是网站都离不开数据库,无论是往数据库里读还是写数据都离不开事务管理,事务管理的核心是锁和并发,采用同步控制的方式保证并发的情况下性能尽可能高服务器每个处理器单位时间内只能做一件事,要。

无论是开发APP还是网站都离不开数据库,无论是往数据库里读还是写数据都离不开事务管理,事务管理的核心是锁和并发,采用同步控制的方式保证并发的情况下性能尽可能高。服务器每个处理器单位时间内只能做一件事,要么读取数据、要么写入数据。

​当多个人去读、写操作时,比如很火的吃鸡游戏,如果不加访问控制,系统势必会产生冲突,服务器就会瘫痪。而事务相当于在读、写操作之外增加了同步的模块,进而保证只有一个线程进入事务当中,而其他线程不会进入,从而避免服务器瘫痪。​事务管理的四大特性分别是:原子型、一致性、隔离性和持久性。

原子性:原子性指的是事务中包含的所有操作要么全做,要么全不做。

一致性:一致性是指在事务开始以前,数据库处于一致性的状态,事务结束后,数据库也必须处于一致性的状态。

隔离性:隔离性要求系统必须保证事务不受其他并发执行的事务的影响。

持久性:持久性是指一个事务一旦成功完成,它对数据库的改变必须是永久的,即使是在系统遇到故障的情况下也不会丢失,数据的重要性决定了事务的持久性的重要。

​事务管理的步骤叫做事务单元。事务单元是通过开始然后提交(Begin-Traction、Commit和Rollback之间所有针对数据的写入、读取的操作都应该添加同步访问),开始和提交之间就是一个同步的事务单元,事务单元之间的Happen-Before关系中的四种关系:读写、写读、读读、写写。所有事务之间的关系都可以抽象成这四种之一来对应现在所有的业务逻辑处理。

如要建立一个基于人员信息的索引、从数据库中读取一行记录、向数据库中写入一行记录,同时更新这行记录的所有索引、删除整张表等都是一个事务单元,事务单元的实现方式Two Phase Lock(2PL)是数据库中非常重要的一个概念。

数据库操作Insert、Update、Add、Delete都是先读再写的操作,例如Insert操作是先读取数据,读取之后判读数据是否存在,如果不存在,则写入该数据,如果数据存在,则返回错误。假设在该场景下没有读操作,只是单纯写入数据,则数据本身并没有事务操作,别的操作与之类似。数据库利用这些操作的特性,在每一次查询过程中,只要查到数据,就会在该数据上加锁。所有被读取的数据都已加锁,不会再被其他人读到,也就是说对数据进行的中间操作状态对所有人都不可见,当所有中间状态完成后,提交操作时,解开锁,此时数据对所有系统可见,只能看到两种状态,比如开始时,A有1000元,B是穷光蛋;结束时,B有1000元,A是穷光蛋,而中间A的钱如何转移到B身上的过程被锁隐藏掉了,这个操作就是数据库中处理事务的最标准的方式。

​事务中的Trx2(JoeLock)与其他事务不相关,因此可以并行执行;Trx1需要Lock两个数据Boblock和Smithlock,而Trx3同样需要Lock这两个数据,因此Trx3必须等待,且等待在Boblock上;Joe事务会先结束,Trx3会等到Trx1完成后才会开始。处理事务的常见方法处理事务的常见方法有排队法、排他锁、读写锁、MVCC等方式。

排队法 :事务处理中最重要也是最简单的方案是排队法,单线程地处理一堆数据。在Redis中,如果数据全部在内存中,则单线程处理所有Put、Get操作效率最高。这是因为多线程本质是CPU模拟多个线程,这种模拟是以上下文切换为代价,而对于内存的数据库来说,没有上下文切换时效率最高。单个CPU绑定一块内存的数据,针对这块数据做多次读写操作时都是在单个CPU上完成的,单线程处理方式在内存的情况是效率是最优的。那么什么时候事务需要用到多线程呢?这个问题的本质取决于下层所使用的存储,如果是内存操作,则可以动态地申请和销毁内存块;而磁盘的IOPS很低,但吞吐量很高。如果一个场景涉及多次读写操作,单线程可以很高的效率对于内存进行读写操作。由于磁盘的IOPS仅为内存的几千分之一,如果依旧用操作内存的方式操作磁盘,那系统的整体性能将会很低,这意味着必须将大量的读写操作聚合成一个Batch后再提交时才能达到较好的性能。而将大量请求攒到一起的方式一是异步,也就是请求本身和线程不绑定,线程可以不Block(本质来说还是一种多线程的方式),处理完一个线程后再处理其他线程。这种做法的核心是将大量不同的请求提交到一个Buff设备中,多线程或异步非常常见,在设计系统时,面对磁盘、网络、SSD等慢速设备必须考虑使用多线程。

排他锁:有些场景不适合用单线程操作,可以利用排他锁的方式来快速隔离并发读写事务。数据库中有一些事务单元是共享的,如事务单元1是共享的,事务单元2/3共享数据;针对事务单元2/3共享数据的所有读写Block住,事务单元1单独用一个锁来控制,用这种方式完成系统的访问控制。

​读写锁:如果是一个只读的事务,例如只对数据进行查询操作,在该过程中数据一定不被修改,因此多个查询操作可以并行执行,因此一种针对读读场景的优化自然而然产生读写锁。读写锁的核心是在多次读的操作中,同时允许多个读者来访问共享资源,提高并发性。

MVCC:在最初的数据库事务实现中是不存在MVCC的,本质是Copy On Write,也就是每次写都是以重新开始一个新的版本的方式写入数据,因此数据库中也就包含了之前的所有版本。在数据读的过程中,先申请一个版本号,如果该版本号小于正在写入的版本号,则数据一定可以查询到,无需等到新版本完全写完即可返回查询结果。这种方式可以在读读不阻塞的前提下,实现读写/写读不阻塞,尽可能保证所有的读操作并行,而写操作串行。

事务的调优思路是在不影响业务应用的前提下用最科学的方法进行调度:

第一,尽可能减少锁的覆盖范围,例如Myisam表锁到Innodb的行锁就是一个减少锁覆盖范围的过程;对于原位锁(排他锁、读写锁等)可变为MVCC多版本(本质仍然是减少锁的范围)。

第二,增加锁上可并行的线程数,例如读锁和写锁的分离,允许并行读取数据。

第三,选择正确锁类型,确保服务器并发控制良好。

    推荐阅读
  • 高考鼓励人的经典语句(高考鼓励人的经典语句精选)

    高考结束心落地,报考志愿心忐忑,有心名校去镀金,无奈分数不允许莘莘学子有志气,天生我材必有用,行行都能出状元,条条大道通罗马,今天小编就来聊一聊关于高考鼓励人的经典语句?莘莘学子有志气,天生我材必有用,行行都能出状元,条条大道通罗马。立志高远,脚踏实地;刻苦钻研,勤学苦思;稳定心态,不馁不弃;全力以赴,夺取胜利。愿落榜的你,鼓起勇气,战胜失败,相信风雨过后,总会有彩虹。

  • 北京国际宠物用品展(第10届北京国际宠物用品展览会)

    敬请相约在中国国际展览中心,第10届北京国际宠物用品展览会盛大开启,规模之大,品质之高,影响力之广,带给观众充足的精彩与展示!第10届北京宠物用品展览会时间:2022年4月1-4日第10届北京宠物用品展览会地点:中国国际展览中心来源:大河票务APP第10届北京国际宠物用品展览会即将于2022年4月1-4日在中国国际展览中心举办,预计展示面积将达120000平方米,1200家展商云集于此,聚焦新风口,引领宠业潮流!

  • 西芹丰产栽培管理技术要点,西芹如何高产养殖

    芹菜可在温室栽培,具有年生产、年销售的特点。播种种子可在常温水中浸泡约8至12小时,然后将水抽干,再将种子放入20度的环境中发芽。种植后1个月左右,可施用NPK复合肥,一般每亩15公斤至20公斤。20至30天后,再次施用速效氮肥。芹菜种植后两个月内一定要保持水分,不能缺水,但同时,水分不宜过大,导致根系干枯。病虫害防治采取“预防为主,综合治理”的原则,预防和减少各种病虫害的发生和危害。严格按照无公害标准使用农药。

  • 如何正确拔罐(怎么拔罐是正确的)

    在点火前,将纱布块叠成块,用钳子加紧,蘸取少量的酒精,在远离人体的地方点燃。防止酒精滴在人体上伤到人。拔罐后的护理,取罐是用一指轻压灌口皮肤,使空气进入罐内,轻轻取下罐子,之后,将皮肤表面用纱布块擦拭干净,皮肤在24小时内不要沾水。将罐口擦洗干净,放在合适的地方,以备后用。因个体差异,有的可能在罐口留下水泡,这些问题不大,小的可以不用处理,稍大的可以将水泡用消毒针刺破,局部消毒即可。

  • 人情炎凉七绝(人情冷暖炎凉世)

    人情冷暖炎凉世,花落花开皆有时。君子万年随本性,堪怜堪惜尽成痴。----七绝·人情冷暖炎凉世

  • 致自己励志说说(盘点致自己励志说说)

    没有天生的信心,只有不断培养的信心。读书要有感受,要有审美感,对他人的金玉良言,要能融会贯通,并使之付诸实现。不要生气要争气,不要看破要突破,不要嫉妒要欣赏,不要托延要积极,不要心动要行动。梦想一旦被付诸行动,就会变得神圣。如果是棵小草,不如历经风雨,把自己培养成名贵花卉。当我们沉溺于过去,感受到的都是伤痛。人生,最璀璨的莫过于事业。一个人,要是不逼自己一把,根本不知道自己有多优秀。

  • 张立演的老大是什么电视剧(有这部剧的剧情说明吗)

    张立演的老大是什么电视剧张立演的老大是《新四大名捕》。剧情简介:该剧以追捕叶三天为首的越狱逃犯为线索,表现公安局118专案组里的四名刑警的大智大勇,为了侦破危害广大人民群众的两起人命案件,做了大量细致、周密的调查,渐渐将目标锁定了以叶三天为首的五人犯罪团伙,并终将这个团伙绳之以法。此剧热情讴歌了以姚长军、夏天、候小雨、杨文来四大名捕为代表的公安民警的英勇善战,无私奉献的可贵精神。

  • 盐焗河虾做法(盐焗河虾做法与步骤)

    接下来我们就一起去了解一下吧!盐焗河虾做法洗净虾,把虾身上的须剪掉,用厨房纸巾吸干水分备用。在锅内平铺一层粗盐,并在粗盐上撒上少许花椒。加热到锅盖微烫时,打开锅盖,将虾放入锅内,盖上锅盖焖虾。3分钟后开盖,给虾翻身,适当搅拌一下再次盖上锅盖焖。

  • 给孩子生日快乐祝福语(给孩子生日快乐祝福语汇总)

    给孩子生日快乐祝福语看着你脸上露出阳光般的笑容,妈妈十分欣喜。生日快乐,儿子!要更乖,更可爱,更懂事哦。岁的生日,一个充满希望与生机的生日。如今,你已长成一个沉稳干练的棒小伙子,爸妈以你为荣!值得记念的日子,原世界因为有了你而更加美好,生日快乐。妈妈对你的爱岂能三言二语只言片语说的完。无论如何,只要你幸福,能干,妈妈也会幸福的。希望你能成为一个有学识,有思想。有主见,有爱心的孩子。

  • 碍怎么读(碍读音及组词)

    解释:使事情不能顺利进行;阻碍:大声说话~别人学习|这个大柜子放在过道里,妨碍走路。正式比赛的距离是三千米。