PostgreSQL如何殺死被鎖死的進(jìn)程問(wèn)題
前言
在一次系統(tǒng)迭代后用戶投訴說(shuō)無(wú)法成功登陸系統(tǒng),經(jīng)過(guò)測(cè)試重現(xiàn)和日志定位,最后發(fā)現(xiàn)是由于用戶在ui上進(jìn)行了某些操作后,觸發(fā)了堆棧溢出異常,導(dǎo)致數(shù)據(jù)庫(kù)里的用戶登陸信息表的數(shù)據(jù)被鎖住,無(wú)法釋放。
這個(gè)表里存放的是用戶的session信息。
雖然后來(lái)解決了問(wèn)題,但是數(shù)據(jù)庫(kù)里這個(gè)用戶登錄信息表里被lock住的數(shù)據(jù)始終無(wú)法釋放,這導(dǎo)致用戶永遠(yuǎn)無(wú)法登陸成功,需要手動(dòng)跑SQL把鎖去掉才行。
殺掉指定進(jìn)程
PostgreSQL提供了兩個(gè)函數(shù):pg_cancel_backend()
和pg_terminate_backend()
,這兩個(gè)函數(shù)的輸入?yún)?shù)是進(jìn)程PID,假定現(xiàn)在要?dú)⑺肋M(jìn)程PID為20407的進(jìn)程,
使用方法如下:
select pg_cancel_backend(20407); --或者執(zhí)行這個(gè)函數(shù)也可以: select pg_terminate_backend(20407);
這兩個(gè)函數(shù)區(qū)別如下:
pg_cancel_backend()
- 只能關(guān)閉當(dāng)前用戶下的后臺(tái)進(jìn)程
- 向后臺(tái)發(fā)送SIGINT信號(hào),用于關(guān)閉事務(wù),此時(shí)session還在,并且事務(wù)回滾
pg_terminate_backend()
- 需要superuser權(quán)限,可以關(guān)閉所有的后臺(tái)進(jìn)程
- 向后臺(tái)發(fā)送SIGTERM信號(hào),用于關(guān)閉事務(wù),此時(shí)session也會(huì)被關(guān)閉,并且事務(wù)回滾
那么如何知道有哪些表、哪些進(jìn)程被鎖住了?
可以用如下SQL查出來(lái):
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%';
這里查的是排它鎖,也可以精確到行排它鎖或者共享鎖之類的。
這里有幾個(gè)重要的column:
a.pid
是進(jìn)程idb.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()
會(huì)把session也關(guān)閉,此時(shí)sessionId會(huì)失效,可能會(huì)導(dǎo)致系統(tǒng)賬號(hào)退出登錄,需要清除掉瀏覽器的緩存cookie(至少我們系統(tǒng)遇到的情況是這樣的)。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用PostgreSQL為表或視圖創(chuàng)建備注的操作
這篇文章主要介紹了使用PostgreSQL為表或視圖創(chuàng)建備注的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01PostgreSQL 恢復(fù)誤刪數(shù)據(jù)的操作
這篇文章主要介紹了PostgreSQL 恢復(fù)誤刪數(shù)據(jù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01phpPgAdmin 配置文件參數(shù)說(shuō)明中文版
這篇文章主要介紹了phpPgAdmin配置文件config.inc.php-dist中注釋的詳細(xì)說(shuō)明,并翻譯成中文,需要的朋友可以參考下2014-03-03PostgreSQL數(shù)據(jù)庫(kù)時(shí)間類型相加減操作
PostgreSQL提供了許多函數(shù),這些函數(shù)返回與當(dāng)前日期和時(shí)間相關(guān)的值,下面這篇文章主要給大家介紹了關(guān)于PostgreSQL數(shù)據(jù)庫(kù)時(shí)間類型相加減操作的相關(guān)資料,需要的朋友可以參考下2023-10-10關(guān)于PostgreSql數(shù)據(jù)庫(kù)與mysql數(shù)據(jù)庫(kù)的不同點(diǎn)以及注意事項(xiàng)
PostgreSQL和MySQL是兩種流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS),它們都可以用來(lái)存儲(chǔ)和管理數(shù)據(jù),但是它們?cè)谀承┓矫嬗兴煌?下面這篇文章主要給大家介紹了關(guān)于PostgreSql數(shù)據(jù)庫(kù)與mysql數(shù)據(jù)庫(kù)的不同點(diǎn)以及注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2023-05-05PostgreSQL 打印日志信息所在的源文件和行數(shù)的實(shí)例
這篇文章主要介紹了PostgreSQL 打印日志信息所在的源文件和行數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法
這篇文章主要為大家詳細(xì)介紹了PostgreSQL更新表時(shí)時(shí)間戳不會(huì)自動(dòng)更新的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10使用PostgreSQL數(shù)據(jù)庫(kù)建立用戶畫(huà)像系統(tǒng)的方法
這篇文章主要介紹了使用PostgreSQL數(shù)據(jù)庫(kù)建立用戶畫(huà)像系統(tǒng),下面使用一個(gè)具體的例子來(lái)說(shuō)明如何使用PostgreSQL的json數(shù)據(jù)類型來(lái)建立用戶標(biāo)簽數(shù)據(jù),需要的朋友可以參考下2022-10-10PostgreSQL+Pgpool實(shí)現(xiàn)HA主備切換的操作
這篇文章主要介紹了PostgreSQL+Pgpool實(shí)現(xiàn)HA主備切換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12