ALTER table ag_event_20141004_20141009 SET (autovacuum_enabled = false,toast.autovacuum_enabled = false);ALTER table ag_event_20141014_20141019 SET (autovacuum_enabled = false,toast.autovacuum_enabled = false);
在此之后(一段时间之后),我看到:
select pID,waiting,xact_start,query_start,query from pg_stat_activity order by query_start; 18092 | f | 2014-11-04 22:21:05.95512+03 | 2014-11-04 22:21:05.95512+03 | autovacuum: VACUUM public.ag_event_20141004_20141009 (to prevent wraparound) 19877 | f | 2014-11-04 22:22:05.889182+03 | 2014-11-04 22:22:05.889182+03 | autovacuum: VACUUM public.ag_event_20141014_20141019 (to prevent wraparound)
我做了什么shell来切换这个表的autovacuuming?
解决方法 这里的关键是:(to prevent wraparound)
这意味着Postgres必须自动清空才能达到free up transaction identifiers.
您不能完全禁用此类型的autovacuum,但可以通过调整autovacuum_freeze_max_age和vacuum_freeze_min_age参数来降低其频率.
总结以上是内存溢出为你收集整理的postgresql – 如何防止Postgres中表的autovacuum全部内容,希望文章能够帮你解决postgresql – 如何防止Postgres中表的autovacuum所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)