On 6/5/26 2:30 PM, Adrian Klaver wrote:

On 6/5/26 5:11 AM, Boris Dovčík wrote:
Hello all,

I have a question regarding the update of the production database (multiple TB of data) from version 12 to higher major version. We would

How many TB?

like to jump to 15 or 16. DB is installed on a Linux server with one replica on another, it is not on cloud.

What replication is being done now?

Where are the servers relative to each other network distance wise?


First question is should we perform updates one by one? 12 -> 13 -> 14 etc. or is it viable to jump to 16 right away? (We have few functions but usually its plain tables)

Second we are contemplating options for the update since we are limited with downtime. We could get 4 hours of downtime for the whole update (either via pg_update or dumps). We are not sure how to estimate the

Did you mean pg_upgrade?

time for direct update or dumps. What would be the recommended way for it?

One option we see could be logical replication to the new major version on a new machine, but we received feedback that in our setup it might

What was the feedback that indicated it was not advisable?

not be recommendable. Does it make sense to try logical replica? What would be the downsides of it?

Best regards,
Boris Dovčík

I've got just a little over 1 TB in prod with a logical replica in the same network.

We upgraded from 10 to 16 in one jump by first setting up the logical replica to run 16 and getting replication up and in sync.

When it came time to do the upgrade from 10 to 16 it was just a few simple steps, and with minimal (less than 5 minutes downtime):

    Stop the pgbouncers, which stopped all network traffic

    Set the sequences on the 16 replica

    Updated pgbouncer configs to point to the 16 server

    Turned the pgbouncers back on

Setting the sequences was the most time consuming part but it was really not long.

Logical replication did the trick for us.

I see that in 19 we won't even have to set the sequences because they are also replicated!  Hooray!

One of the advantages to the logical replication route is that we could take advantage of testing a ton of our code against 16 on the replica *before* we ever flipped the switch.

Jeff

P.S.  I can't wait to hear how I did it all wrong or could have done it better but this absolutely worked ;-)



Reply via email to