pgsql鎖表后kill進(jìn)程的操作
如下:
select * from pg_stat_activity
查詢系統(tǒng)中的進(jìn)程

如果懷疑哪張表被鎖了,可以執(zhí)行如下sql:
select oid from pg_class where relname='table_name'
然后將拿到的oid 放入如下sql執(zhí)行:
select pg_cancel_backend('oid ');;
搞定!
此sql是kill作用
補(bǔ)充:PostgreSQL - 如何殺死被鎖死的進(jìn)程
前言
在一次系統(tǒng)迭代后用戶投訴說無法成功登陸系統(tǒng),經(jīng)過測試重現(xiàn)和日志定位,最后發(fā)現(xiàn)是由于用戶在ui上進(jìn)行了某些操作后,觸發(fā)了堆棧溢出異常,導(dǎo)致數(shù)據(jù)庫里的用戶登陸信息表的數(shù)據(jù)被鎖住,無法釋放。這個表里存放的是用戶的session信息。
雖然后來解決了問題,但是數(shù)據(jù)庫里這個用戶登錄信息表里被lock住的數(shù)據(jù)始終無法釋放,這導(dǎo)致用戶永遠(yuǎn)無法登陸成功,需要手動跑SQL把鎖去掉才行。
殺掉指定進(jìn)程
PostgreSQL提供了兩個函數(shù):pg_cancel_backend()和pg_terminate_backend(),這兩個函數(shù)的輸入?yún)?shù)是進(jìn)程PID,假定現(xiàn)在要?dú)⑺肋M(jìn)程PID為20407的進(jìn)程,使用方法如下:
select pg_cancel_backend(20407);
--或者執(zhí)行這個函數(shù)也可以:
select pg_terminate_backend(20407);
這兩個函數(shù)區(qū)別如下:
pg_cancel_backend()
只能關(guān)閉當(dāng)前用戶下的后臺進(jìn)程
向后臺發(fā)送SIGINT信號,用于關(guān)閉事務(wù),此時session還在,并且事務(wù)回滾
pg_terminate_backend()
需要superuser權(quán)限,可以關(guān)閉所有的后臺進(jìn)程
向后臺發(fā)送SIGTERM信號,用于關(guān)閉事務(wù),此時session也會被關(guān)閉,并且事務(wù)回滾
那么如何知道有哪些表、哪些進(jìn)程被鎖住了?可以用如下SQL查出來:
select * from pg_locks a join pg_class b on a.relation = b.oid join pg_stat_activity c on a.pid = c.pid where a.mode like '%ExclusiveLock%';
這里查的是排它鎖,也可以精確到行排它鎖或者共享鎖之類的。這里有幾個重要的column:a.pid是進(jìn)程id,b.relname是表名、約束名或者索引名,a.mode是鎖類型。
殺掉指定表指定鎖的進(jìn)程
select pg_cancel_backend(a.pid) from pg_locks a join pg_class b on a.relation = b.oid join pg_stat_activity c on a.pid = c.pid where b.relname ilike '表名' and a.mode like '%ExclusiveLock%';
--或者使用更加霸道的pg_terminate_backend():
select pg_terminate_backend(a.pid) from pg_locks a join pg_class b on a.relation = b.oid join pg_stat_activity c on a.pid = c.pid where b.relname ilike '表名' and a.mode like '%ExclusiveLock%';
另外需要注意的是,pg_terminate_backend()會把session也關(guān)閉,此時sessionId會失效,可能會導(dǎo)致系統(tǒng)賬號退出登錄,需要清除掉瀏覽器的緩存cookie(至少我們系統(tǒng)遇到的情況是這樣的)。
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
PostgreSQL如何查詢表結(jié)構(gòu)和索引信息
文章介紹了在PostgreSQL中查詢表結(jié)構(gòu)和索引信息的幾種方法,包括使用`\d`元命令、系統(tǒng)數(shù)據(jù)字典查詢以及使用可視化工具DBeaver2024-12-12
PostgreSQL 實(shí)現(xiàn)將多行合并轉(zhuǎn)為列
這篇文章主要介紹了PostgreSQL 實(shí)現(xiàn)將多行合并轉(zhuǎn)為列的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
使用postgresql 模擬批量數(shù)據(jù)插入的案例
這篇文章主要介紹了使用postgresql 模擬批量數(shù)據(jù)插入的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
PostgreSQL的generate_series()函數(shù)的用法說明
這篇文章主要介紹了PostgreSQL的generate_series()函數(shù)的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
Postgresql psql文件執(zhí)行與批處理多個sql文件操作
這篇文章主要介紹了Postgresql psql文件執(zhí)行與批處理多個sql文件操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
詳解PostgreSQL中實(shí)現(xiàn)數(shù)據(jù)透視表的三種方法
數(shù)據(jù)透視表(Pivot Table)是進(jìn)行數(shù)據(jù)匯總、分析、瀏覽和展示的強(qiáng)大工具,可以幫助我們了解數(shù)據(jù)中的對比情況、模式和趨勢,是數(shù)據(jù)分析師和運(yùn)營人員必備技能之一,本給大家介紹PostgreSQL中實(shí)現(xiàn)數(shù)據(jù)透視表的三種方法,需要的朋友可以參考下2024-04-04
PostgreSQL使用MySQL作為外部表(mysql_fdw)
PostgreSQL 提供了一種訪問和操作外部數(shù)據(jù)源的機(jī)制,稱為外部數(shù)據(jù)包裝器,本文主要給大家介紹了PostgreSQL使用MySQL作為外部表的方法,感興趣的朋友跟隨小編一起看看吧2022-11-11
CentOS PostgreSQL 12 主從復(fù)制(主從切換)操作
這篇文章主要介紹了CentOS PostgreSQL 12 主從復(fù)制(主從切換)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除
這篇文章主要介紹了postgresql如何找到表中重復(fù)數(shù)據(jù)的行并刪除問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05

