Re: Add a perl function in Cluster.pm to generate WAL
От | Bharath Rupireddy |
---|---|
Тема | Re: Add a perl function in Cluster.pm to generate WAL |
Дата | |
Msg-id | CALj2ACUkXXsCTNoqhTr=S-CV7qdCB=QEiMvuuo31brLkLz4o6w@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Add a perl function in Cluster.pm to generate WAL (Michael Paquier <michael@paquier.xyz>) |
Ответы |
Re: Add a perl function in Cluster.pm to generate WAL
|
Список | pgsql-hackers |
On Fri, Jun 16, 2023 at 8:00 AM Michael Paquier <michael@paquier.xyz> wrote: > > On Thu, Jun 15, 2023 at 01:40:15PM +0900, Kyotaro Horiguchi wrote: > > + "CREATE TABLE tt (); DROP TABLE tt; SELECT pg_switch_wal();"); > > > > At least since 11, we can utilize pg_logical_emit_message() for this > > purpose. It's more lightweight and seems appropriate, not only because > > it doesn't cause any side effects but also bacause we don't have to > > worry about name conflicts. > > Making this as cheap as possible by design is a good concept for a > common routine. +1. While it seems reasonable to use pg_logical_emit_message, it won't work for all the cases - what if someone wants to advance WAL by a few WAL files? I think pg_switch_wal() is the way, no? For instance, the replslot_limit.pl test increases the WAL in a very calculated way - it increases by 5 WAL files. So, -1 to use pg_logical_emit_message. I understand the naming conflicts for the table name used ('tt' in this case). If the table name 'tt' looks so simple and easy for someone to have tables with that name in their tests file, we can generate a random table name in advance_wal, something like in the attached v2 patch. > > - SELECT 'finished';", > > - timeout => $PostgreSQL::Test::Utils::timeout_default)); > > -is($result[1], 'finished', 'check if checkpoint command is not blocked'); > > - > > +$node_primary2->advance_wal(1); > > +$node_primary2->safe_psql('postgres', 'CHECKPOINT;'); > > > > This test anticipates that the checkpoint could get blocked. Shouldn't > > we keep the timeout? > > Indeed, this would partially invalidate what's getting tested in light > of 1816a1c6 where we run a secondary command after the checkpoint. So > the last SELECT should remain around. Changed. > > -$node_primary->safe_psql( > > - 'postgres', "create table retain_test(a int); > > - select pg_switch_wal(); > > - insert into retain_test values(1); > > - checkpoint;"); > > +$node_primary->advance_wal(1); > > +$node_primary->safe_psql('postgres', "checkpoint;"); > > > > The original test generated some WAL after the segment switch, which > > appears to be a significant characteristics of the test. > > Still it does not matter for this specific case? The logical slot has > been already invalidated, so we don't care much about logical changes > in WAL, do we? Correct, the slot has already been invalidated and the test is verifying that WAL isn't retained by the invalidated slot, so essentially what it needs is to generate "some" wal. So, using advance_wal there seems fine to me. CFBot doesn't complain anything - https://github.com/BRupireddy/postgres/tree/add_a_TAP_test_function_to_generate_WAL_v2. Attached the v2 patch. Thoughts? -- Bharath Rupireddy PostgreSQL Contributors Team RDS Open Source Databases Amazon Web Services: https://aws.amazon.com
Вложения
В списке pgsql-hackers по дате отправления: