PostgreSQL中的死锁和锁等待[通俗易懂]

PostgreSQL中的死锁和锁等待[通俗易懂]开始之前明确一下死锁和锁等待这两个事件的异同相同的之处:两者都是当前事物在试图请求被其他事物已经占用的锁,从而造成当前事物无法执行的现象不同的之处:死锁是相关session双方或者多方中必然要牺牲(回

PostgreSQL中的死锁和锁等待

 

开始之前明确一下死锁和锁等待这两个事件的异同
相同的之处:两者都是当前事物在试图请求被其他事物已经占用的锁,从而造成当前事物无法执行的现象
不同的之处:死锁是相关session双方或者多方中必然要牺牲(回滚)至少一个事务,否则双方(或者多方)都无法执行;锁等待则不然,对于暂时无法申请到的锁,尝试持续地“等待一段时间”,这个等待的时间就是“锁等待”参数决定,超出之后就不等了。 当事物锁等待超时后,当前事物已经持有的锁如何处理,是一个非常考究的问题,
对于MySQL来说,可以选择回滚整个事务,或者是仅回滚当前锁超时的语句,具体参考这里:https://www.cnblogs.com/wy123/p/12724252.html
下文对Postgresql中锁超时之后当前Session中事务和语句的处理进行一个验证。

Postgresql的死锁检测机制

锁等待有可能是发展成死锁,也有可能不是死锁,可能继续等待一段时间之后就可以正常申请到所需要的锁了。
发生死锁的情况下,一定会产生锁等待,因为此时的锁等待没有任何意义,所以必须(立刻)牺牲其中一个事务。
在MySQ中有一个死锁自动检测开关,没有死锁等待时间一说,因为一旦死锁的条件生成,则没有任何缓冲的余地,必须至少牺牲(回滚)其中一个事物,释放其占用的锁,来打断这个死锁的闭环。
但是在Postgresql中,有一个死锁等待事件的参数,默认是1s中,也就是是说Postgresql后台进程会以1s的频率来检测是否存在死锁。
PostgreSQL中的死锁和锁等待[通俗易懂]
换句话说就是,在Postgresql的死锁检测机制中,不是以MySQL中那种实时监测方式来处理死锁的。
为什么postgresql中对于死锁要以类似于定时轮训的方式来实现死锁检测而不是实时监测?

回答这个问题之前,先回到MySQL中:
上面提到MySQL中的死锁自动检测机制是有一个开关的,当然这个开关是可以关闭的,也就是系统不检测死锁信息,那么在死锁发生后也就无法自动牺牲其中一个事务。
那为什么还要允许这个开关设置为关闭呢?其实死锁检测也是需要代价的,尤其是实时监测,参考这里:https://mp.weixin.qq.com/s/Lc_tQEK55r_syapebSu0Cg,提到过通过关闭死锁检测来提升性能的最佳实践。

然后回到Postgresql中:
在Postgresql中,deadlock_timeout是进行死锁检测之前在一个锁上等待的总时间(以毫秒计)。Postgresql的理念中认为死锁检测代价是比较高的,因此服务器不会在每次等待锁时都运行这个它(是不是死锁)。我们乐观地假设在生产应用中死锁是不常出现的,并且只在开始检测死锁之前等待一会儿。增加这个值就减少了浪费在无用的死锁检测上的时间(频率),但是降低了报告真正死锁错误的速度。默认是 1 秒(1s),这可能是实际中你想要的最小值。在一个高负载的服务器上,你可能需要增大它。这个值的理想设置应该超过你通常的事务时间,这样就可以减少在锁释放之前就开始死锁检查的机会。同理,对于高并发小事务处理系统上,默认的1秒已经足够了。只有超级用户可以更改这个设置。
参考:https://postgresqlco.nf/zh/doc/param/deadlock_timeout/

Postgresql锁超时

Postgresql中同样可以设置所等待的超时时间,意味着当前事务在请求一个锁的时候,一旦等待时长超出指定的时间,当前语句被中止。

该参数的默认值为0,意味着发生锁等待的时候永远不超时,一直等待下去。


PostgreSQL中的死锁和锁等待[通俗易懂]

与statement_timeout不同,这个超时只在等待锁时发生。注意如果statement_timeout为非零,设置lock_timeout为相同或更大的值没有意义,因为事务超时将总是先与锁超时触发。
官网说不推荐在postgresql.conf中设置lock_timeout,因为它会影响所有会话。

实际这个建议值得商榷,如果不设置lock_timeout,一个Session的锁等待将无限拉长(如果statement_timeout不限制的话),一旦大量的连接涌入进来等待一个短时间内无法释放的不兼容锁,那么数据库的连接数可能在段时间被打爆,影响一些正常的连接。这里认为应该系统中事务轻重程度,设置成超过deadlock_timeout且小于statement_timeout的一个值,强制一些超锁超时的Session自动终止,不要无限期等待,引发系统性的异常。

Postgresql中的锁超时后事务的处理

相比MySQL给予了用户充分的自由,在超等待超时后,可以选择设置回滚当前语句,或者回滚整个事务(参数
innodb_rollback_on_timeout决定),Postgresql中是如何处理的呢?

可以创建一个死锁Session,当前事务作为牺牲品牺牲之后,出现current transaction is aborted, commands ignored until end of transaction block

当前Session作为牺牲品之后,回滚的是整个事务,这个容易理解


PostgreSQL中的死锁和锁等待[通俗易懂]


PostgreSQL中的死锁和锁等待[通俗易懂]

对于锁超时之后当前Session的情况呢,设置一个锁超时的时间


PostgreSQL中的死锁和锁等待[通俗易懂]

制造一个锁超时的场景,锁超时之后,当前Session的任何语句都会被回滚,即便是执行一个commit,当前Session锁超时后的Session状态,虽然还是一个活动事务,但能且只能回滚。


PostgreSQL中的死锁和锁等待[通俗易懂]

锁超时之后的Session状态
PostgreSQL中的死锁和锁等待[通俗易懂]
可见,默认情况下,Postgresql在当前Session锁超时之后,会回滚整个事务,而不是当前语句,这样其实更加的科学合理,MySQL也是这么建议的。

最后,Postgresql中的deadlock_timeout,设置成不同的值,一方面取决于业务,另外一方面,对系统整体的性能影响,该如何科学地衡量?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/7166.html

(0)
上一篇 2023-03-25
下一篇 2023-03-25

相关推荐

  • 腾讯短网址怎么在线生成[亲测有效]

    腾讯短网址怎么在线生成[亲测有效]短网址生成指的是把帮您把冗长的URL地址缩短成8个字符以内的短网址。 那为什么要生成短链接呢? 最基础的,日常在用到微信朋友圈、qq说说、短信、微博等,都有字数的限制。如果链接长度较长,链接发送不全…

    2023-04-04
    168
  • Python 3中map函数的用法

    Python 3中map函数的用法map()函数是Python内置的高阶函数,它接收一个函数和一个可迭代对象作为参数,根据函数对可迭代对象中的每一个元素进行处理,最终返回一个新的可迭代对象。

    2024-06-15
    44
  • mysql安装及使用教程_安装应用程序

    mysql安装及使用教程_安装应用程序【目录】 1、将MySQL服务 制作成windows服务 2、设置密码 3、忘记密码(激活成功教程密码) 【Windows系统】 1、将MySQL服务 制作成windows服务(即 可以开机自启动) 补充:c

    2023-02-24
    148
  • mysql表示日期的数据类型_sql定义日期数据类型

    mysql表示日期的数据类型_sql定义日期数据类型类型名称日期格式日期范围存储需求 YEAR YYYY 1901 ~ 2155 1 个字节 TIME HH:MM:SS -838:59:59 ~ 838:59:59 3 个字节 DATE YYYY-MM

    2023-02-16
    150
  • win10一键重装系统「建议收藏」

    win10一键重装系统「建议收藏」今天小编要给大家介绍的是云骑士装机大师win10一键重装系统,一键系统重装,无需电脑技术,小白在家也可自己完成安装,三步到位,安全简单!一键系统重装,0费用,0丢包,极加速!一起来看看吧。 1第一步…

    2023-04-12
    164
  • mysqlbinlog增量恢复[亲测有效]

    mysqlbinlog增量恢复[亲测有效][TOC] 前言 mysqlbinlog工具的作用是解析mysql的二进制binlog的日志内容,把二进制日志解析成可以在MySQL数据库里执行的SQL语句。 1.mysql的binlog日志是什么

    2023-02-27
    155
  • 5大步骤+10个案例,堪称SQL优化万能公式[亲测有效]

    5大步骤+10个案例,堪称SQL优化万能公式[亲测有效]在应用开发的早期,数据量少,开发人员开发功能时更重视功能上的实现,随着生产数据的增长,很多SQL语句开始暴露出性能问题,对生产的影响也越来越大,有时可能这些有问题的SQL就是整个系统性能的瓶颈。

    2023-06-09
    143
  • Oracle学习(八) — SQL优化「建议收藏」

    Oracle学习(八) — SQL优化「建议收藏」1、前置工具:执行计划 Explain Plan 1.1、概念 一条查询语句在 ORACLE 中的执行过程或访问路径的描述。即就是对一个查询任务,做出一份怎样去完成任务的详细方案。 执行计划:用于记…

    2023-03-09
    176

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注