查询 pg_stat_progress_vacuum 不返回任何内容

问题描述

我目前使用以下数据库 Postgresql 11.10(在 Debian 上运行)。

这个数据库非常大,有 1200 多个模式,每个模式有 130 多个表。

我目前使用以下配置更频繁地运行 autovacuum:

autovacuum_analyze_scale_factor: 0.02
autovacuum_naptime: 5s
autovacuum_multixact_freeze_max_age: 120000000
vacuum_multixact_freeze_table_age: 96000000
vacuum_multixact_freeze_min_age: 1000000
autovacuum_max_workers: 64
autovacuum_vacuum_cost_limit: 3000
autovacuum_vacuum_cost_delay: 10
autovacuum_vacuum_scale_factor: 0.01
maintenance_work_mem: 4096MB

我以前可以获取每个 autovacuum 的状态或进度,但由于某种原因,我无法获取 autovacuum 的状态。

postgres=# SELECT * FROM pg_stat_progress_vacuum LIMIT 1;
(0 rows)

我觉得这很奇怪,因为我看到每个查询都在运行许多活动的 autovacuum。

postgres=# SELECT
  pid,Now() - xact_start AS duration,query,state
FROM pg_stat_activity
WHERE query LIKE 'autovacuum%'
ORDER BY duration DESC LIMIT 64;

仅供参考,数据库和副本运行在拥有大量资源的节点上。

我不确定我是否必须弄乱 max_worker_processesmax_parallel_maintenance_workersmax_parallel_workers,因为 documentation 并没有真正告诉我它们是否与自动吸尘器工人。

除非我了解正在发生的事情,否则我真的不想更改生产设置。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...