好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > pgsql鎖表后kill進程的操作

pgsql鎖表后kill進程的操作

熱門標簽:打電話智能電銷機器人授權 漯河外呼電話系統 合肥公司外呼系統運營商 美容工作室地圖標注 海豐有多少商家沒有地圖標注 重慶自動外呼系統定制 外呼調研系統 地圖標注和圖片名稱的區別 辦公外呼電話系統

如下:

select * from pg_stat_activity

查詢系統中的進程

如果懷疑哪張表被鎖了,可以執行如下sql:

select oid from pg_class where relname='table_name'

然后將拿到的oid 放入如下sql執行:

select pg_cancel_backend('oid ');;

搞定!

此sql是kill作用

補充:PostgreSQL - 如何殺死被鎖死的進程

前言

在一次系統迭代后用戶投訴說無法成功登陸系統,經過測試重現和日志定位,最后發現是由于用戶在ui上進行了某些操作后,觸發了堆棧溢出異常,導致數據庫里的用戶登陸信息表的數據被鎖住,無法釋放。這個表里存放的是用戶的session信息。

雖然后來解決了問題,但是數據庫里這個用戶登錄信息表里被lock住的數據始終無法釋放,這導致用戶永遠無法登陸成功,需要手動跑SQL把鎖去掉才行。

殺掉指定進程

PostgreSQL提供了兩個函數:pg_cancel_backend()和pg_terminate_backend(),這兩個函數的輸入參數是進程PID,假定現在要殺死進程PID為20407的進程,使用方法如下:

select pg_cancel_backend(20407);

--或者執行這個函數也可以:

select pg_terminate_backend(20407);

這兩個函數區別如下:

pg_cancel_backend()

只能關閉當前用戶下的后臺進程

向后臺發送SIGINT信號,用于關閉事務,此時session還在,并且事務回滾

pg_terminate_backend()

需要superuser權限,可以關閉所有的后臺進程

向后臺發送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是進程id,b.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會失效,可能會導致系統賬號退出登錄,需要清除掉瀏覽器的緩存cookie(至少我們系統遇到的情況是這樣的)。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • pgsql之pg_stat_replication的使用詳解
  • pgsql 如何刪除仍有活動鏈接的數據庫
  • pgsql的UUID生成函數實例
  • pgsql 如何手動觸發歸檔
  • pgsql 實現用戶自定義表結構信息獲取
  • PGSQL 實現把字符串轉換成double類型(to_number())
  • pgsql之create user與create role的區別介紹

標簽:晉城 珠海 株洲 蚌埠 來賓 烏海 衡陽 錦州

巨人網絡通訊聲明:本文標題《pgsql鎖表后kill進程的操作》,本文關鍵詞  pgsql,鎖表,后,kill,進程,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pgsql鎖表后kill進程的操作》相關的同類信息!
  • 本頁收集關于pgsql鎖表后kill進程的操作的相關信息資訊供網民參考!
  • 推薦文章