From: | Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com> |
---|---|
To: | 와따가따 <lght2000(at)gmail(dot)com> |
Cc: | pgsql-bugs(at)lists(dot)postgresql(dot)org |
Subject: | Re: [issue] wal_buffers_full increases depending on the values of wal_buffers and wal-segsize |
Date: | 2022-04-28 03:40:08 |
Message-ID: | CAD21AoB2nj2Cpb+Wwn4dLtgDoVqvGMjCHed5Lwj3eouBM16bdQ@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
Hi,
On Mon, Apr 25, 2022 at 9:19 PM 와따가따 <lght2000(at)gmail(dot)com> wrote:
>
> If the wal segment size is larger than the wal_buffers parameter value, the value of the wal_buffers_full column of pg_stat_wal increases after database shutdown and startup.
>
> pg_controldata | grep "Bytes per WAL segment"
> Bytes per WAL segment: 1073741824
>
> wal_buffers = 16MB
>
>
> ---- DB shutdown and restart
> postgres=# select * from pg_stat_wal;
> wal_records | wal_fpi | wal_bytes | wal_buffers_full | wal_write | wal_sync | wal_write_time | wal_sync_time | stats_reset
> -------------+---------+-----------+------------------+-----------+----------+----------------+---------------+-------------------------------
> 6165 | 462 | 14071380 | 126070 | 126115 | 40 | 0 | 0 | 2022-04-25 14:28:04.746772+09
> (1 row)
>
>
> If wal_buffers size and wal_segment size are the same, wal_buffers_full column does not increase.
>
> pg_controldata | grep "Bytes per WAL segment"
> Bytes per WAL segment: 16777216
>
> wal_buffers = 16MB
>
> postgres=# select * from pg_stat_wal;
> wal_records | wal_fpi | wal_bytes | wal_buffers_full | wal_write | wal_sync | wal_write_time | wal_sync_time | stats_reset
> -------------+---------+-----------+------------------+-----------+----------+----------------+---------------+-------------------------------
> 6161 | 461 | 14062929 | 0 | 39 | 36 | 0 | 0 | 2022-04-25 12:13:35.838092+09
> (1 row)
>
>
>
> Is this a bug?
>
> The postgreSQL version currently in use is 14.2, and the database was restarted without performing DML and DDL.
>
> I wonder if it doesn't matter if the values of wal_buffers and wal-segsize are different.
I've reproduced a similar symptom by calling pg_switch_wal() on the
database cluster that is initialized with --wal-segsize=1024 (1GB):
$ pg_controldata | grep "WAL seg"
Bytes per WAL segment: 1073741824
=# select wal_buffers_full, wal_write from pg_stat_wal;
wal_buffers_full | wal_write
------------------+-----------
0 | 0
(1 row)
=# select pg_switch_wal();
pg_switch_wal
---------------
0/40699860
(1 row)
=# select wal_buffers_full, wal_write from pg_stat_wal
wal_buffers_full | wal_write
------------------+-----------
128180 | 128181
(1 row)
I think it's not a bug. When switching a WAL segment, we have to
consume all the remaining space in the WAL segment. wal_buffers_full
is incremented whenever we have to write out one (8kB) WAL block of
the (16MB) WAL buffers after using up the WAL buffers. Therefore,
During filling up the remaining 1GB WAL segment, wal_buffers_full is
incremented about 130,000 times (=1GB / 8kB), which seems to be a
similar value you got. On the other hand, with the 16MB WAL segment,
the WAL buffers were not used up, wal_buffers_full was not
incremented. I guess something like this happened on your database.
Regards,
--
Masahiko Sawada
EDB: https://www.enterprisedb.com/
From | Date | Subject | |
---|---|---|---|
Next Message | Wilm Hoyer | 2022-04-28 09:31:17 | AW: BUG #17448: In Windows 10, version 1703 and later, huge_pages doesn't work. |
Previous Message | Julien Rouhaud | 2022-04-27 16:52:28 | Re: BUG #17448: In Windows 10, version 1703 and later, huge_pages doesn't work. |