如何解决PostgreSQL执行语句长时间卡着不动,不报错也不执行的问题?

news/2024/11/21 1:48:03/

1 问题现象

执行SQL语句,卡着不动,不成功也不执行,就像挂住了一样。
truncate table simple;
在这里插入图片描述

2 原因分析

一般来说,语句呈现卡着的状态,主要会是两种原因比较多,
原因1:SQL语句是一个耗时操作,正常场景下执行的时候本来就耗时。
原因2:SQL语句中涉及到的表或者说对象处于锁定状态。
现在来看当前的问题,truncate table simple; 我们看这个语句应该会执行的很快才对,
如果是delete * from simple;那如果simple表里面数据量大的话是会比较慢的。
因此,这里大概率是表被锁住了。

3 数据库表被锁住了,如何处理?

3.1 查询一下当前数据库的活动监控pg_stat_activity

执行语句:
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)

通过上面执行语句得到的结果,可以看到我们执行truncate table simple的语句进程id是641,它处于Lock状态,Lock的原因是因为592阻塞导致。
因此,要先解决592进程。

3.2 中断阻塞进程

pg_terminate_backend(需要被中断的进程号)
pg_terminate_backend函数说明:

test=# select pg_terminate_backend(592);pg_terminate_backend
----------------------t
(1 row)

3.3 检查前面的执行是否成功

刚刚卡着的,中断阻塞的进程后,立刻就完成执行了。如下图所示:
在这里插入图片描述

4 pg_stat_activity表定义

                  View "pg_catalog.pg_stat_activity"
ColumnTypeCollationNullableDefault
------------------±-------------------------±----------±---------±--------
datidoid
datnamename
pidinteger
usesysidoid
usenamename
application_nametext
client_addrinet
client_hostnametext
client_portinteger
backend_starttimestamp with time zone
xact_starttimestamp with time zone
query_starttimestamp with time zone
state_changetimestamp with time zone
wait_event_typetext
wait_eventtext
statetext
backend_xidxid
backend_xminxid
querytext
backend_typetext

https://www.postgresql.org/docs/14/monitoring-stats.html#MONITORING-PG-STAT-ACTIVITY-VIEW


http://www.ppmy.cn/news/803557.html

相关文章

java获取qq_QQ中,获取消息

首先创建一个Message类,先设置三个属性,发送方、接收方、消息内容,代表所有的属性。 Message: Messagepackage com.dr.QQ; public class Message {private String from; private String to; private String content; public String getFrom() {return from; } public void …

游戏.消息管理器

/**************************************************WinMain.cpp堆栈式的函数管理器http://blog.csdn.net/chinayaosir**************************************************///0.头文件#include <windows.h>#include <stdio.h>//1.管理器类定义class cProcessMan…

QQ管理器

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using System.Data.SqlClient;namespace QQ信息管理系统 {class UserManager{public void Login(){int count 0;do{string strUserName string.Empty;//初始化管…

android 消息管理器,腾讯TIM消息管理器在哪 腾讯TIM打开消息管理器的教程

腾讯TIM最新简介 tim最新版主要是在“日程”方面进行了改进&#xff0c;比如在聊天界面点击日程时&#xff0c;可以新建日程和分享我的日程、日程界面支持周视图展示等。另外&#xff0c;更新还精简代码&#xff0c;缩减安装包大小&#xff0c;屏蔽了送礼物等功能和动画。 腾讯…

Debezium日常分享系列之:Debezium 信号发送和通知 - 第 1 部分

Debezium日常分享系列之&#xff1a;Debezium 信号发送和通知 - 第 1 部分 一、背景二、Debezium 中的信号发送三、Debezium 中的通知四、结论 一、背景 本系列文章将介绍 Debezium 提供的信号和通知功能&#xff0c;并讨论与平台交互的可用渠道。在本系列的后续部分中&#x…

学习推荐

编程类 类Unix系统的编程书籍里&#xff0c;最经典的莫过于简称为APUE的《Advanced Programming in the UNIX Environment》&#xff08;中译名是“Unix环境高级编程”&#xff09;&#xff0c;这本书被广大Unix程序员&#xff08;包括Linux&#xff09;捧为“圣经”。借用葛大…

js的数组解构

数组解构&#xff08;Array Destructuring&#xff09;时&#xff0c;有几个重要的概念需要了解&#xff1a; 基本数组解构&#xff1a; 可以使用方括号&#xff08;[]&#xff09;来定义解构模式。解构模式将数组中的值分配给对应的变量。解构是基于位置的&#xff0c;变量的…

推荐一款Python 代码自动补全神器

是时候跟你说说这个能让你撸代码撸得舒服得不要不要的神器了——kite。 简单来说&#xff0c;它是一款 IDE 的插件&#xff0c;能做到代码自动补全&#xff0c;可能你会说了&#xff0c;这有什么牛逼的&#xff1f;一般的编辑器不都有这个功能么&#xff1f; 它虽然是一个插件&…