问题描述
我目前使用以下数据库 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 (将#修改为@)