首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何解决此错误“需要冻结xid截止值1601650960之前的未提交xmin 1358613895”。

如何解决此错误“需要冻结xid截止值1601650960之前的未提交xmin 1358613895”。
EN

Stack Overflow用户
提问于 2020-03-10 15:09:24
回答 1查看 1.4K关注 0票数 1

下面是postgresql日志文件中的错误。寻求关于如何修复它们的帮助。

PostgreSQL版本为9.6

==> PostgreSQL2020-03-10日志<==

代码语言:javascript
运行
复制
2020-03-10 10:48:19 EAT|||ERROR:  uncommitted xmin 1358613895 from before xid cutoff 1601650960 needs to be frozen
2020-03-10 10:48:19 EAT|||CONTEXT:  automatic vacuum of table "schema.public.tablename"

==> PostgreSQL2020-03-10.csv <==

代码语言:javascript
运行
复制
2020-03-10 10:48:19.140 EAT,,,22943,,5e67463b.599f,1,,2020-03-10 10:48:11 EAT,13/281,0,ERROR,XX001,"uncommitted xmin 1358613895 from before xid cutoff 1601650960 needs to be frozen",,,,,"automatic vacuum of table "schema.public.tablename"
EN

回答 1

Stack Overflow用户

发布于 2020-04-14 17:51:12

有几件事你想要核实:

  1. 找到任何长时间打开的准备事务

代码语言:javascript
运行
复制
    SELECT * FROM pg_prepared_xacts ;

  1. 检查是否有与1358613895

开放的事务

代码语言:javascript
运行
复制
SELECT * FROM pg_stat_activity WHERE backend_xid = 1358613895 OR backend_xmin = 1358613895

代码语言:javascript
运行
复制
SELECT * FROM pg_stat_activity WHERE now() - xact_start <= INTERVAL '1 days'

如果您发现任何使用上述SQL的长事务,则取消事务。如果您无法找到任何长事务,则可以执行以下操作之一: a.关闭Postgres并在单用户模式下运行PostgreSQL并执行真空操作。b.在一项交易中,执行下列操作

代码语言:javascript
运行
复制
     BEGIN;
     CREATE TABLE public.tablename_copy AS SELECT * FROM public.tablename;
     TRUNCATE TABLE public.tablename;
     INSERT INTO public.tablename SELECT * FROM public.tablename_copy;
     DROP TABLE public.tablename_copy;
     END;
代码语言:javascript
运行
复制
 -- OR ---
代码语言:javascript
运行
复制
     BEGIN;
     COPY public.tablename TO '/tmp/tablename.data';
     TRUNCATE TABLE public.tablename;
     COPY public.tablename FROM '/tmp/tablename.data';
     END;

执行

代码语言:javascript
运行
复制
VACUUM FREEZE ANALYZE;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60620438

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档