postgresql锁
admin
2023-05-21 00:42:09
0

postgresql锁:

postgresql中有3种锁模式,分别为:spinlock、lwlook和regularlock。


1、spinlock自旋锁

  spinlock使用互斥信息,与操作系统和硬件环境联系比较密切。spinlocky的主要特点是封锁的时间很短,没有等待队列和死锁检测机制。事务结束时,不能自动释放spinlock锁。


2、LWLock轻量级锁

  LWLock主要提供对共享存储器的数据结构的互斥访问。LWLock的主要特点是由等待队列和无死锁检测。事务结束时,可以自动释放lwlock。lwlock可分为排他模式和共享模式。

  排他模式:用于数据修改操作,例如:insert、update或delete,确保不会同时对同一资源进行多重更新。

  共享模式:用于读取数据操作,允许多个事务读取相同的数据,但不允许其他事务修改当前数据,如select语句。


3、regularlock常规锁

 regularlock为一般数据库事务管理中所指的锁。regularlock的主要特点为有等待队列、有死锁检测和能自动释放锁。

 regularlock支持的锁的模式有8种,按排他级别从低到高分别是:access share,row share,row exclusive,share update exclusive,share,share row exclusive,exclusive,access exclusive;

 ①:access share(访问共享锁):查询命令(select)将会在查询的表上获取访问共享锁。一般任何一个对表上的只读查询操作都将获取这种类型的锁。此模式的锁和access exclusive(访问排他锁)是冲突的。

 ②:row share(行共享锁):使用“select for update”或“select for share”命令将获得行共享锁。另外,此锁和exclusive(排他锁)和access exclusive(访问排他锁)是冲突的。

 ③:row exclusive(行排他锁):使用update、delete或insert命令会在目标表上获得行排他锁。并且在其他被引用的表上加上access share锁。一般,更改表数据的命令都将在这张表上获得row exclusive锁。另外,此锁和share(共享锁)、share row exclusive(共享行排他锁)、exclusive(排他锁)和access exclusive(访问排他锁)是冲突的。

 ④:share update exclusive(共享更新排他锁):使用vacuum(不带full选项)analyze或create index concurrently语句时使用共享更新排他锁。

 ⑤:share(共享锁):使用create index(不带concurrently选项)语句请求时用共享锁。

 ⑥:share row exclusive(共享行排他锁):和排他锁类似,但是允许行共享。

 ⑦:exclusive(排他锁):阻塞行共享和select for update时使用排他锁。

 ⑧:access exclusive(访问排他锁):alter table,drop table,truncate,reindex,cluster或vacuum full命令会获得访问排他锁。在lock table命令中,如果没有生命其他模式,access exclusive就是默认模式。


5、死锁:

  在两个或多个任务中,如果每个任务锁定了其他任务视图锁定的资源,就会造成这些任务永久阻塞,从而出现死锁。此时系统处于死锁状态。


形成死锁的4个必要条件:

①:请求与保持条件:获取资源的进程可以同时申请新的资源。

②:非剥夺条件:已经分配的资源不能从该进程中剥夺。

③:循环等待条件:多个进程构成环路,并且每个进程都在等待相邻进程正占用的资源。

④:互斥条件:资源只能被一个进程使用。


减少死锁的方法:

①:在所有事务中都以相同的次序使用资源。

②:使事务尽可能简单并在一个批处理中。

③:为死锁超时参数设置一个合理范围,如3-30分钟;超时则自动放弃本操作,避免进程挂起。

④:避免在事务内核用户进行交互,减少资源的锁定时间。

⑤:使用较低的隔离级别,相比较高的隔离级别能够有效减少持有共享锁的时间,减少锁之间的竞争。


例子:

--:使用命令锁定一个表,语法如下:

 lock  [table]  name  [,...] [in lockmode mode] [nowait]

 其中,name为要锁定的现存表的名字;lockmode为锁模式,声明这个锁和哪些锁冲突,如果没有声明锁模式,默认为access exclusive模式;nowait声明lock table不会等待任何冲突的锁释放,如果不得不等待获取所要求的锁,就会推出事务。

如:lock  table  emp;  或者  lock table a,b;


相关内容

热门资讯

河南一地行政区划调整 据微信公众号“内黄人大”消息,5月14日,内黄县十六届人大常委会第三十六次会议在县人大常委会会议室召...
2026华南城家居建材博览会暨... 5月12日,2026华南城家居建材博览会暨第 16 届郑州华南城・中部(春季)建材五金展销会圆满落下...
双双大涨,河南一天新增两家上市... 【大河财立方 记者 王磊彬 夏晨翔 北京 深圳报道】 5月18日,河南资本市场再次迎来高光时刻。郑州...
如何看待下阶段中国经济走势?国... 【大河财立方消息】5月18日,国新办举行新闻发布会,介绍2026年4月份国民经济运行情况。国家统计局...
奥克斯电热水器插电不显示不加热 奥克斯电热水器插电不显示不加热1、奥克斯电热水器插电后既不显示也不加热,首先想到的原因是电源是否正常...
马桶不上水水箱不上水什么原因 马桶不上水可能由以下原因导致:1. 进水阀故障:进水阀是控制马桶水箱进水的关键部件,如果进水阀出现故...
马桶上水不停 里面一直往外流水... 出现马桶上水不停,里面一直往外流水这样的情况可能是因水箱质量问题所引起的,有些在质量上会比较劣质,使...
马桶水箱一直流水声音而且不上水 马桶水箱一直流水声音而且不上水1、可能是马桶补水器中的滤网被水垢给堵住了,导致自来水进不来,因此,在...
马桶安装   先将下水口用钢锯或者角膜据水平高度0.5厘米即可,为什么要预留0.5厘米呢,因为马桶的法兰是软的...
河南省高级人民法院原副巡视员刘... 经中共河南省委批准,河南省纪委监委对省高级人民法院原副巡视员刘国松严重违纪违法问题进行了立案审查调查...