pg_wal lifecycle - Mailing list pgsql-general

From Luca Ferrari
Subject pg_wal lifecycle
Date
Msg-id CAKoxK+4L069ZjNAtJ9Vwio6wRVSw0Cpp50+SJ=QdRskogGcrfA@mail.gmail.com
Whole thread Raw
Responses Re: pg_wal lifecycle
List pgsql-general
Hi all,
I'd like to see if I get it right about pg_wal: it grows up to pretty
much max_wal_size, at which point a checkpoint is triggered.
If the server triggers a timed checkpoint before the pg_wal is at
max_wal_size, the system recycles the wals thus keeping the pg_wal
size lower than max_wal_size.
Is this correct? In particular, what is in simple words, the
discrimination between recycling a segment and creating a new one?


% sudo du -hs $PGDATA/pg_wal/
273M    /postgres/13/data/pg_wal/
% psql -U postgres -c "show max_wal_size;" -c "show checkpoint_timeout;"
 max_wal_size
--------------
 1GB
(1 riga)

 checkpoint_timeout
--------------------
 5min
(1 riga)

and from the last log checkpoint entry:

2021-07-13 02:48:10.492 EDT [2424] LOG:  checkpoint starting: time
2021-07-13 02:50:44.515 EDT [2424] LOG:  checkpoint complete: wrote
9170 buffers (28.0%); 0 WAL file(s) added, 0 removed, 13 recycled;
write=148.878 s, sync=1.889 s, total=154.023 s; sync files=42,
longest=0.109 s, average=0.045 s; distance=217376 kB, estimate=217376
kB

Thanks,
Luca



pgsql-general by date:

Previous
From: Tom Lane
Date:
Subject: Re: How to debug a connection that's "active" but hanging?
Next
From: Peter Eisentraut
Date:
Subject: Re: libicu global support