这篇文章主要介绍“Oracle的死锁分析”,在日常操作中,相信很多人在Oracle的死锁分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Oracle的死锁分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!发生死锁的多个进程执行的都是同一个存储过程,大概代码及顺序如下:session Asession Bsession C可能还会有更多的session处于执行语句2,并等待enq: TX – row lock contention的情况,这里暂时只列3个session,其实2个也够了,也能形成,只是概率很低。等待链
A被C堵塞,C被B堵塞,B被A堵塞等待链分析:
A执行到语句3了,说明主键为orderno_a的order数据行锁和ch2的channel数据行锁已经获取到了,而其余的B和C只能等待该ch2数据的行锁释放。
B和C都执行到语句2了,说明他们都获取到了各自的order数据行锁,且数据不是orderno_a所代表的数据。这点毋庸置疑。疑问:A,B,C操作的都是不同的订单数据行,且都获取到了各自的行锁的,为什么在表order上,还会发生A被C堵塞呢。要知道为什么有这个疑问,就要先明白,在A执行order的for update时是已经获取了itl资源的,所以在后来真正update数据时是不应该存在这个等待的enq: TX – allocate ITL entry,因为他已经获取这个资源了。要分析这个死锁就要明白等待事件enq: TX – allocate ITL entry所代表的资源itl事务槽的含义。itl事务槽是数据块头中用来标记事务的记录。在这里有个重点是数据块。想一想,如果事务跨数据块了会怎样。这就是这个死锁的关键点。当然不同表的事务肯定跨数据块了,一个事务即使修改一个表的多条数据也可能跨块了。这里免费云主机域名的情况是,order表上事务都是通过主键来操作的,对于一条数据,要跨越数据块,行迁移或者行连接会有这种情况。行迁移一般是update后经常出现,比如一个err_mesg字段,初期只有10个字符,后面update为1000个字符,如果这个时候原数据块装不下了,他就会找另外的数据块来存放,而原数据块上放一个新数据块的dba(data block address),指向新的数据块,如下图:
行连接一般是insert时出现的,比如一条数据非常大,大到一个块装不下了,oracle会拆分成多个块来存放。可以通过创建块尺寸小的表空间来测试。到此处,要明白itl是数据块上的资源,即使是同一个事务中,如果事务跨数据块了,当他要修改这个数据块时,他也需要重新再次在这个新块上申请itl资源,也就是我这里死锁中,假设orderno_a数据rowid指向的块为dba_1,行迁移中指向的块为dba_2,在最开始for update时获取的是块dba_1中的itl资源,当最后真正update数据时,为了保护操作,需要获取dba_2上的itl资源。而此时,其余的很多session,比如B,C……N 等等session将块dba_2上的itl资源耗尽了,那么session A就处于等待数据块dba_2上的itl资源的状态,对应于enq: TX – allocate ITL entry。而其他session将等待session A释放渠道表数据的锁。完成了锁的闭环到此死锁分析完毕。到此,关于“Oracle的死锁分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注百云网站,小编会继续努力为大家带来更多实用的文章!
这篇文章将为大家详细讲解有关Redis中支持的数据类型有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(so…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。