PostgreSQL Locks的基础知识有哪些
这篇文章主要介绍“PostgreSQL Locks的基础知识有哪些”,在日常操作中,相信很多人在PostgreSQL Locks的基础知识有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PostgreSQL Locks的基础知识有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
PostgreSQL把锁分为三类,table-level, row-level and advisory locks.Table和Row级锁可以是显式或隐式锁,advisory locks通常是显式锁.显式锁在显式用户请求时获得,而隐式锁则通过标准SQL命令获得.
Advisory Locks
PG提供了应用自定义的locks,这种locks称为Advisory Locks — 系统并没有强制使用这些锁,由应用自行正确使用.
有两种方法请求获取advisory lock : Session Level和Transaction Level.
session level : 一旦在session level获取了锁,除非session终止或者显式的释放,否则锁会一直持有.不同于标准的锁请求,session level的advisory lock不需要遵守事务语义:在事务期间申请的lock会在rollback后仍会持有,同时就算事务调用失败unlock也是有效的.lock可以多次获取,对于每一次完整的锁请求必须在释放锁前有相应的unlock.
transaction level : 与普通锁类似,在事务结束时自动释放,没有显式的unlock操作.
对于同一个Advisory Lock,如果同时请求session leve和transaction level的锁,那么会以期望的方式阻塞.
下面是Advisory Lock的例子:
session 1
[local]:5432pg12@testdb=#--Transaction1[local]:5432pg12@testdb=#BEGIN;BEGINTime:0.882ms[local]:5432pg12@testdb=#*[local]:5432pg12@testdb=#*SELECTpg_advisory_xact_lock(1);pg_advisory_xact_lock-----------------------(1row)Time:2.449ms[local]:5432pg12@testdb=#*--Someworkhere[local]:5432pg12@testdb=#*
session 2
[local]:5432pg12@testdb=#--Transaction2[local]:5432pg12@testdb=#BEGIN;BEGINTime:0.468ms[local]:5432pg12@testdb=#*[local]:5432pg12@testdb=#*SELECTpg_advisory_xact_lock(1);
session 3
[local]:5432pg12@testdb=#SELECT*FROMpg_lockswherepid<>pg_backend_pid();locktype|database|relation|page|tuple|virtualxid|transactionid|classid|objid|objsubid|virtualtransaction|pid|mode|granted|fastpath------------+----------+----------+------+-------+------------+---------------+---------+-------+----------+--------------------+------+---------------+---------+----------virtualxid|||||5/4|||||5/4|1789|ExclusiveLock|t|tvirtualxid|||||4/13|||||4/13|1787|ExclusiveLock|t|tadvisory|16384||||||0|1|1|5/4|1789|ExclusiveLock|t|fadvisory|16384||||||0|1|1|4/13|1787|ExclusiveLock|f|f(4rows)Time:3.748ms
通过查询pg_locks,可以看到pid 1789持有advisory lock(granted = t),而pid 1787在等待该锁(granted = f).
到此,关于“PostgreSQL Locks的基础知识有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。