PostgreSQL如何殺死被鎖死的進程問題
前言
在一次系統(tǒng)迭代后用戶投訴說無法成功登陸系統(tǒng),經過測試重現(xiàn)和日志定位,最后發(fā)現(xiàn)是由于用戶在ui上進行了某些操作后,觸發(fā)了堆棧溢出異常,導致數據庫里的用戶登陸信息表的數據被鎖住,無法釋放。
這個表里存放的是用戶的session信息。
雖然后來解決了問題,但是數據庫里這個用戶登錄信息表里被lock住的數據始終無法釋放,這導致用戶永遠無法登陸成功,需要手動跑SQL把鎖去掉才行。
殺掉指定進程
PostgreSQL提供了兩個函數:pg_cancel_backend()和pg_terminate_backend(),這兩個函數的輸入參數是進程PID,假定現(xiàn)在要殺死進程PID為20407的進程,
使用方法如下:
select pg_cancel_backend(20407); --或者執(zhí)行這個函數也可以: select pg_terminate_backend(20407);
這兩個函數區(qū)別如下:
pg_cancel_backend()
- 只能關閉當前用戶下的后臺進程
- 向后臺發(fā)送SIGINT信號,用于關閉事務,此時session還在,并且事務回滾
pg_terminate_backend()
- 需要superuser權限,可以關閉所有的后臺進程
- 向后臺發(fā)送SIGTERM信號,用于關閉事務,此時session也會被關閉,并且事務回滾
那么如何知道有哪些表、哪些進程被鎖住了?
可以用如下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是進程idb.relname是表名、約束名或者索引名a.mode是鎖類型
殺掉指定表指定鎖的進程
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也關閉,此時sessionId會失效,可能會導致系統(tǒng)賬號退出登錄,需要清除掉瀏覽器的緩存cookie(至少我們系統(tǒng)遇到的情況是這樣的)。
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用PostgreSQL為表或視圖創(chuàng)建備注的操作
這篇文章主要介紹了使用PostgreSQL為表或視圖創(chuàng)建備注的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01
關于PostgreSql數據庫與mysql數據庫的不同點以及注意事項
PostgreSQL和MySQL是兩種流行的關系型數據庫管理系統(tǒng)(RDBMS),它們都可以用來存儲和管理數據,但是它們在某些方面有所不同,下面這篇文章主要給大家介紹了關于PostgreSql數據庫與mysql數據庫的不同點以及注意事項的相關資料,需要的朋友可以參考下2023-05-05
使用PostgreSQL數據庫建立用戶畫像系統(tǒng)的方法
這篇文章主要介紹了使用PostgreSQL數據庫建立用戶畫像系統(tǒng),下面使用一個具體的例子來說明如何使用PostgreSQL的json數據類型來建立用戶標簽數據,需要的朋友可以參考下2022-10-10
PostgreSQL+Pgpool實現(xiàn)HA主備切換的操作
這篇文章主要介紹了PostgreSQL+Pgpool實現(xiàn)HA主備切換操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12

