高斯锁表导致sql报错处理

构造锁等待场景:

1.打开一个新的连接会话,使用普通用户连接GaussDB(DWS)数据库,在test SCHEMA 下创建测试表test.ypg_test。

CREATE TABLE ypg_test (id int, name varchar(50));

2.开启事务1,进行INSERT操作。

START TRANSACTION;

INSERT INTO test.ypg_test VALUES (1, 'lily');

3.打开一个新的连接会话,使用系统管理员dbadmin连接GaussDB(DWS)数据库,执行VACUUM FULL操作,发现语句阻塞。

VACUUM FULL test.ypg_test;

锁等待检测(8.1.x及以上版本)

1.打开一个新的连接会话,使用系统管理员dbadmin连接GaussDB(DWS)数据库,通过pgxc_lock_conflicts视图查看锁冲突情况。

如下图,回显中查看granted字段为"f",表示VACUUM FULL语句正在等待其他锁。granted字段为"t",表示INSERT语句是持有锁。nodename,表示锁产生在的位置,即CN或DN位置,例如cn_5001。

SELECT * FROM pgxc_lock_conflicts;

2.据语句内容确认是否中止持锁语句。如果终止,则执行以下语句。pid从1获取,cn_5001为上面查询到的nodename。

execute direct on (cn_5001) 'SELECT PG_TERMINATE_BACKEND(pid)';

锁等待检测(8.0.x及以前版本)

1.在数据库中执行以下语句,获取VACUUM FULL操作对应的query_id。

SELECT * FROM pgxc_stat_activity WHERE query LIKE '%vacuum%'AND waiting = 't';

2.根据获取的query_id,执行以下语句查看是否存在锁等待,并获取对应的tid。其中,{query_id}从1获取。

SELECT * FROM pgxc_thread_wait_status WHERE query_id = {query_id};

回显中"wait_status"存在"acquire lock"表示存在锁等待。同时查看"node_name"显示在对应的CN或DN上存在锁等待,记录相应的CN或DN名称,例如cn_5001或dn_600x_600y。

3.执行以下语句,到等锁的对应CN或DN上通过查询pg_locks系统表查看VACUUM FULL操作在等待哪个锁。以下以cn_5001为例,如果在DN上等锁,则改为相应的DN名称。pid为2获取的tid。

回显中记录relation的值。

execute direct on (cn_5001) 'SELECT * FROM pg_locks WHERE pid = {tid} AND granted = ''f''';

4.根据获取的relation,通过查询pg_locks系统表查看当前持有锁的pid。{relation}从3获取。

execute direct on (cn_5001) 'SELECT * FROM pg_locks WHERE relation = {relation} AND granted = ''t''';

5.根据pid,执行以下语句,查到对应的SQL语句。{pid}从4获取。

execute direct on (cn_5001) 'SELECT query FROM pg_stat_activity WHERE pid={pid}';

6.根据语句内容确认是中止持锁语句还是待持锁语句结束再重新执行VACUUM FULL。如果终止,则执行以下语句。pid从4获取。

中止结束后,再尝试重新执行VACUUM FULL。

execute direct on (cn_5001) 'SELECT PG_TERMINATE_BACKEND(pid)';

相关推荐
TDengine (老段)2 小时前
TDengine 数学函数 DEGRESS 用户手册
大数据·数据库·sql·物联网·时序数据库·iot·tdengine
TDengine (老段)2 小时前
TDengine 数学函数 GREATEST 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
安当加密3 小时前
云原生时代的数据库字段加密:在微服务与 Kubernetes 中实现合规与敏捷的统一
数据库·微服务·云原生
爱喝白开水a3 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
想ai抽3 小时前
深入starrocks-多列联合统计一致性探查与策略(YY一下)
java·数据库·数据仓库
武子康3 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
longgyy3 小时前
5 分钟用火山引擎 DeepSeek 调用大模型生成小红书文案
java·数据库·火山引擎
ytttr8734 小时前
C# 仿QQ聊天功能实现 (SQL Server数据库)
数据库·oracle·c#
盒马coding5 小时前
第18节-索引-Partial-Indexes
数据库·postgresql
dingdingfish5 小时前
关于Oracle RAC和ADG的学习资料
oracle·database·adg·rac·ha·dr·maa