如何解決PostgreSQL執(zhí)行語(yǔ)句長(zhǎng)時(shí)間卡著不動(dòng)不報(bào)錯(cuò)也不執(zhí)行的問(wèn)題
1 問(wèn)題現(xiàn)象
執(zhí)行SQL語(yǔ)句,卡著不動(dòng),不成功也不執(zhí)行,就像掛住了一樣。
truncate table simple;
2 原因分析
一般來(lái)說(shuō),語(yǔ)句呈現(xiàn)卡著的狀態(tài),主要會(huì)是兩種原因比較多,
原因1:SQL語(yǔ)句是一個(gè)耗時(shí)操作,正常場(chǎng)景下執(zhí)行的時(shí)候本來(lái)就耗時(shí)。
原因2:SQL語(yǔ)句中涉及到的表或者說(shuō)對(duì)象處于鎖定狀態(tài)。
現(xiàn)在來(lái)看當(dāng)前的問(wèn)題,truncate table simple; 我們看這個(gè)語(yǔ)句應(yīng)該會(huì)執(zhí)行的很快才對(duì),
如果是delete * from simple;那如果simple表里面數(shù)據(jù)量大的話是會(huì)比較慢的。
因此,這里大概率是表被鎖住了。
3 數(shù)據(jù)庫(kù)表被鎖住了,如何處理?
3.1 查詢一下當(dāng)前數(shù)據(jù)庫(kù)的活動(dòng)監(jiān)控pg_stat_activity
執(zhí)行語(yǔ)句:
select pg_blocking_pids(pid),pid,now()-xact_start,wait_event,wait_event_type,substr(query,1,100) from pg_stat_activity where state <> ‘idle' order by 3 desc;
test=# select pg_blocking_pids(pid),pid,now()-xact_start,wait_event,wait_event_type,substr(query,1,100) from pg_stat_activity where state <> 'idle' order by 3 desc; pg_blocking_pids | pid | ?column? | wait_event | wait_event_type | substr ------------------+-----+-----------------+------------+-----------------+---------------------------------------------------------------------------------------------- -------- {} | 592 | 00:53:35.188996 | ClientRead | Client | lock table simple in access exclusive mode; {592} | 641 | 00:17:37.498617 | relation | Lock | truncate table simple; {} | 750 | 00:00:00 | | | select pg_blocking_pids(pid),pid,now()-xact_start,wait_event,wait_event_type,substr(query,1,1 00) fro (3 rows)
通過(guò)上面執(zhí)行語(yǔ)句得到的結(jié)果,可以看到我們執(zhí)行truncate table simple的語(yǔ)句進(jìn)程id是641,它處于Lock狀態(tài),Lock的原因是因?yàn)?92阻塞導(dǎo)致。
因此,要先解決592進(jìn)程。
3.2 中斷阻塞進(jìn)程
pg_terminate_backend(需要被中斷的進(jìn)程號(hào))
pg_terminate_backend函數(shù)說(shuō)明:
test=# select pg_terminate_backend(592); pg_terminate_backend ---------------------- t (1 row)
3.3 檢查前面的執(zhí)行是否成功
剛剛卡著的,中斷阻塞的進(jìn)程后,立刻就完成執(zhí)行了。如下圖所示:
4 pg_stat_activity表定義
View "pg_catalog.pg_stat_activity"
Column | Type | Collation | Nullable | Default |
---|---|---|---|---|
------------------±-------------------------±----------±---------±-------- | ||||
datid | oid | |||
datname | name | |||
pid | integer | |||
usesysid | oid | |||
usename | name | |||
application_name | text | |||
client_addr | inet | |||
client_hostname | text | |||
client_port | integer | |||
backend_start | timestamp with time zone | |||
xact_start | timestamp with time zone | |||
query_start | timestamp with time zone | |||
state_change | timestamp with time zone | |||
wait_event_type | text | |||
wait_event | text | |||
state | text | |||
backend_xid | xid | |||
backend_xmin | xid | |||
query | text | |||
backend_type | text |
https://www.postgresql.org/docs/14/monitoring-stats.html#MONITORING-PG-STAT-ACTIVITY-VIEW
總結(jié)
到此這篇關(guān)于如何解決PostgreSQL執(zhí)行語(yǔ)句長(zhǎng)時(shí)間卡著不動(dòng)不報(bào)錯(cuò)也不執(zhí)行問(wèn)題的文章就介紹到這了,更多相關(guān)PostgreSQL執(zhí)行語(yǔ)句長(zhǎng)時(shí)間不動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
PostgreSQL 設(shè)置允許訪問(wèn)IP的操作
這篇文章主要介紹了PostgreSQL 設(shè)置允許訪問(wèn)IP的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12PostgreSQL中使用數(shù)組改進(jìn)性能實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于PostgreSQL中使用數(shù)組改進(jìn)性能的相關(guān)資料,文中通過(guò)示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12postgresql synchronous_commit參數(shù)的用法介紹
這篇文章主要介紹了postgresql synchronous_commit參數(shù)的用法介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12PostgreSQL時(shí)間相差天數(shù)代碼實(shí)例
PostgreSQL是一款簡(jiǎn)介而又性能強(qiáng)大的數(shù)據(jù)庫(kù)應(yīng)用程序,其在日期時(shí)間數(shù)據(jù)方面所支持的功能也都非常給力,這篇文章主要給大家介紹了關(guān)于PostgreSQL時(shí)間相差天數(shù)的相關(guān)資料,需要的朋友可以參考下2023-11-11基于postgresql數(shù)據(jù)庫(kù)鎖表問(wèn)題的解決
這篇文章主要介紹了基于postgresql數(shù)據(jù)庫(kù)鎖表問(wèn)題的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12postgresql修改完端口后直接psql連接數(shù)據(jù)庫(kù)報(bào)錯(cuò)的解決
這篇文章主要介紹了postgresql修改完端口后直接psql連接數(shù)據(jù)庫(kù)報(bào)錯(cuò)的解決,具有很好的參考價(jià)值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01PostgreSQL進(jìn)行重置密碼的方法小結(jié)
今天想測(cè)試一個(gè)PostgresSQL語(yǔ)法的 SQL,但是打開(kāi)PostgresSQL之后沉默了,密碼是什么?日長(zhǎng)月久的,漸漸就忘記了,于是開(kāi)始了尋找密碼的道路,所以本文介紹了Postgresql忘記密碼,如何重置密碼,需要的朋友可以參考下2024-05-05