On Fri, Feb 22, 2013 at 5:57 AM, Stefan Andreatta
<s.andrea...@synedra.com>wrote:

> Hi,
>
> If I understand http://www.postgresql.org/**docs/9.1/static/routine-**
> vacuuming.html<http://www.postgresql.org/docs/9.1/static/routine-vacuuming.html>correctly,
>  the autovacuum threshold in could be estimated like this in
> PostgreSQL 9.1:
>
> SELECT pg_stat_user_tables.relname,
>      pg_stat_user_tables.n_dead_**tup,
>      CAST(current_setting('**autovacuum_vacuum_threshold') AS bigint)
>          + (CAST(current_setting('**autovacuum_vacuum_scale_**factor') AS
> numeric)
>             * pg_class.reltuples) AS av_threshold
>  FROM pg_stat_user_tables
>      JOIN pg_class on pg_stat_user_tables.relid = pg_class.oid
>  ORDER BY 1;
>
> If pg_stat_user_tables.n_dead_tup exceeds av_threshold autovacuum should
> kick in. Obviously, that does rely on up-to-date statistics. Is that how it
> is actually done?
>

Pretty much, yes.  With the caveat that table storage settings can override
the global settings.


>
> 2nd question: because pg_stat_user_tables.n_dead_tup is itself estimated
> by ANALYZE it cannot be used as a criterion for the next autoanalyze run, I
> think.


n_dead_tup is updated by the stats collector, not by ANALYZE.

Cheers,

Jeff

Reply via email to