From: | Guillaume Lelarge <guillaume(at)lelarge(dot)info> |
---|---|
To: | Franjo Stipanovic <fritzfs(at)gmail(dot)com> |
Cc: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, pgsql-general(at)lists(dot)postgresql(dot)org |
Subject: | Re: Different Autovacuum Settings on Master and Replica in Streaming Replication |
Date: | 2025-01-17 21:11:01 |
Message-ID: | CAECtzeUbYPH7ff+D=7dTmooJo4_+OtfTvzy0p4vFsWptg1VaKA@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
Le ven. 17 janv. 2025 à 18:12, Franjo Stipanovic <fritzfs(at)gmail(dot)com> a
écrit :
> Thank you, Guillaume, Tom.
>
> In that case, querying pg_stat_user_tables on replica for last_vacuum,
> last_autovacuum, last_analyze, and last_autoanalyze columns makes no sense?
> Those specific columns are not transferred from the master? The same goes
> for n_* columns? Currently, on my replica, all those columns are null and
> 0, while on the master they have a value.
>
Right. It makes no sense to replicate the activity statistics of the
primary to the secondary. You'll get the activity statistics of the primary
on the primary, and the activity statistics of the secondary on the
secondary.
And so, all activity statistics columns related to write operations will be
either NULL or 0 on the secondary/replica because there are no write
operations on a replica.
Seems like only seq_scan, last_seq_scan, idx_scan, ... are fulfilled.
>
>
Those come from some read operations on the replica.
> Also, data behind pg_stats (n_distinct, most_common_vals,
> most_common_freqs, etc) is replicated, right? It seems that we can query
> those just fine.
>
>
Right. Those aren't activity statistics. They are data statistics, and they
are replicated. They're needed by the planner on the primary and on the
secondary.
> On Fri, Jan 17, 2025 at 4:34 PM Guillaume Lelarge <guillaume(at)lelarge(dot)info>
> wrote:
>
>> Hi,
>>
>> Le ven. 17 janv. 2025 à 15:38, Franjo Stipanovic <fritzfs(at)gmail(dot)com> a
>> écrit :
>>
>>> Question regarding autovacuum settings in a PostgreSQL streaming
>>> replication setup. Specifically, I am curious about whether it is possible
>>> (and advisable) to have different values for the following settings on the
>>> master and replica databases:
>>> - autovacuum_vacuum_scale_factor
>>> - autovacuum_analyze_scale_factor
>>>
>>> Can the above settings be configured differently on the master and
>>> replica databases in a streaming replication setup? I just tested this on
>>> AWS RDS Postgres.
>>>
>>
>> They could but it doesn't matter. VACUUM and ANALYZE aren't executed on
>> replicas because they are write operations, and you can't write on replicas.
>>
>>
>>> How would those different settings interact with replication, for
>>> example, if I apply change on master, would it be replicated to replica and
>>> override my replica setting?
>>>
>> Changes on the postgresq.conf file aren't replicated, but ALTER TABLE ...
>> (SET autovacuum...) are.
>>
>>> I was expecting that this is not possible in streaming replication, only
>>> in logical replication.
>>>
>>
>> You're right, it's not possible.
>>
>>
>> --
>> Guillaume.
>>
>
>
> --
> best wishes,
> Franjo Stipanovic
>
--
Guillaume.
From | Date | Subject | |
---|---|---|---|
Next Message | Alex Burkhart | 2025-01-18 10:44:07 | Design of a reliable task processing queue |
Previous Message | Brent Wood | 2025-01-17 20:43:16 | concatenating hstores in a group by? |