主頁(yè) > 知識(shí)庫(kù) > pgsql鎖表后kill進(jìn)程的操作

pgsql鎖表后kill進(jìn)程的操作

熱門標(biāo)簽:打電話智能電銷機(jī)器人授權(quán) 漯河外呼電話系統(tǒng) 合肥公司外呼系統(tǒng)運(yùn)營(yíng)商 美容工作室地圖標(biāo)注 海豐有多少商家沒有地圖標(biāo)注 重慶自動(dòng)外呼系統(tǒng)定制 外呼調(diào)研系統(tǒng) 地圖標(biāo)注和圖片名稱的區(qū)別 辦公外呼電話系統(tǒng)

如下:

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)過測(cè)試重現(xiàn)和日志定位,最后發(fā)現(xiàn)是由于用戶在ui上進(jìn)行了某些操作后,觸發(fā)了堆棧溢出異常,導(dǎo)致數(shù)據(jù)庫(kù)里的用戶登陸信息表的數(shù)據(jù)被鎖住,無法釋放。這個(gè)表里存放的是用戶的session信息。

雖然后來解決了問題,但是數(shù)據(jù)庫(kù)里這個(gè)用戶登錄信息表里被lock住的數(shù)據(jù)始終無法釋放,這導(dǎo)致用戶永遠(yuǎn)無法登陸成功,需要手動(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查出來:

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)程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()會(huì)把session也關(guān)閉,此時(shí)sessionId會(huì)失效,可能會(huì)導(dǎo)致系統(tǒng)賬號(hào)退出登錄,需要清除掉瀏覽器的緩存cookie(至少我們系統(tǒng)遇到的情況是這樣的)。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • pgsql之pg_stat_replication的使用詳解
  • pgsql 如何刪除仍有活動(dòng)鏈接的數(shù)據(jù)庫(kù)
  • pgsql的UUID生成函數(shù)實(shí)例
  • pgsql 如何手動(dòng)觸發(fā)歸檔
  • pgsql 實(shí)現(xiàn)用戶自定義表結(jié)構(gòu)信息獲取
  • PGSQL 實(shí)現(xiàn)把字符串轉(zhuǎn)換成double類型(to_number())
  • pgsql之create user與create role的區(qū)別介紹

標(biāo)簽:晉城 珠海 株洲 蚌埠 來賓 烏海 衡陽(yáng) 錦州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《pgsql鎖表后kill進(jìn)程的操作》,本文關(guān)鍵詞  pgsql,鎖表,后,kill,進(jìn)程,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《pgsql鎖表后kill進(jìn)程的操作》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于pgsql鎖表后kill進(jìn)程的操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章