如何解决查询 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_processes
、max_parallel_maintenance_workers
和 max_parallel_workers
,因为 documentation 并没有真正告诉我它们是否与自动吸尘器工人。
除非我了解正在发生的事情,否则我真的不想更改生产设置。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。