n_live_tup
Live row estimateDimensions:None
Interface Metrics (3)
Dimensions:None
Sources
Technical Annotations (17)
Configuration Parameters (6)
autovacuum_vacuum_scale_factorrecommended: 0.01 for high-churn tablesautovacuum_analyze_scale_factorrecommended: 0.005autovacuum_vacuum_cost_delayrecommended: 2autovacuum_max_workersrecommended: 5-6 for high-write workloadsautovacuum_vacuum_thresholdrecommended: 50autovacuum_vacuum_cost_limitrecommended: 1000CLI Commands (6)
VACUUM ANALYZE table_name;remediationSELECT schemaname, relname AS table_name, n_live_tup AS live_tuples, n_dead_tup AS dead_tuples, ROUND(n_dead_tup::numeric / NULLIF(n_live_tup, 0) * 100, 2) AS dead_pct, last_autovacuum, last_autoanalyze, autovacuum_count, autoanalyze_count FROM pg_stat_user_tables ORDER BY n_dead_tup DESC LIMIT 20;diagnosticALTER TABLE events SET (autovacuum_vacuum_threshold = 1000, autovacuum_vacuum_scale_factor = 0.005, autovacuum_analyze_threshold = 500, autovacuum_analyze_scale_factor = 0.005, autovacuum_vacuum_cost_delay = 0, autovacuum_vacuum_cost_limit = 3000);remediationSELECT schemaname, relname AS table_name, n_dead_tup AS dead_tuples, n_live_tup AS live_tuples, last_autovacuum, last_autoanalyze, CASE WHEN n_live_tup > 0 THEN round(100.0 * n_dead_tup / n_live_tup, 1) ELSE 0 END AS dead_tuple_ratio FROM pg_stat_user_tables WHERE n_dead_tup > 500 ORDER BY n_dead_tup DESC LIMIT 15;diagnosticALTER TABLE sim_events SET (autovacuum_vacuum_scale_factor = 0.02, autovacuum_vacuum_threshold = 500, autovacuum_vacuum_cost_delay = 2, autovacuum_vacuum_cost_limit = 1000);remediationSELECT relname, reloptions FROM pg_class WHERE relname = 'sim_events';diagnosticTechnical References (5)
pg_stat_user_tablescomponentMVCCconceptdead tuplesconcepttable bloatconceptHOT updatesconceptRelated Insights (3)
High dead tuple ratio causes table bloat and slow querieswarning
▸
High dead tuple percentage causes query degradation and cache inefficiencywarning
▸
Autovacuum triggers too late on large tables causing bloat and query degradationwarning
▸