| From: | Greg Stark <stark(at)mit(dot)edu> | 
|---|---|
| To: | Bharath Rupireddy <bharath(dot)rupireddyforpostgres(at)gmail(dot)com> | 
| Cc: | Jeremy Schneider <schneider(at)ardentperf(dot)com>, Bruce Momjian <bruce(at)momjian(dot)us>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, SATYANARAYANA NARLAPURAM <satyanarlapuram(at)gmail(dot)com>, marvin_liang(at)qq(dot)com, actyzhang(at)outlook(dot)com, Ashutosh Sharma <ashu(dot)coek88(at)gmail(dot)com> | 
| Subject: | Re: pg_walinspect - a new extension to get raw WAL data and WAL stats | 
| Date: | 2022-02-02 17:01:12 | 
| Message-ID: | CAM-w4HOUVrZ81FnQVZkaXA6Mq3SWAoubL8UhbatX622H3Wpymw@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
Additionally I've looked at the tests and I'm not sure but I don't
think this arrangement is going to work. I don't have the time to run
CLOBBER_CACHE and CLOBBER_CACHE_ALWAYS tests but I know they run
*really* slowly. So the test can't just do a CHECKPOINT and then trust
that the next few transactions will still be in the wal to decode
later. There could have been many more timed checkpoints in between.
I think the way to do it is to create either a backup label or a
replication slot. Then you can inspect the lsn of the label or slot
and decode all transactions between that point and the current point.
I also think you should try to have a wider set of wal records in that
range to test decoding records with and without full page writes, with
DDL records, etc.
I do like that the tests don't actually have the decoded record info
in the test though. But they can do a minimal effort to check that the
records they think they're testing are actually being tested. Insert
into a temporary table and then run a few queries with WHERE clauses
to test for a heap insert, btree insert test the right relid is
present, and test that a full page write is present (if full page
writes are enabled I guess). You don't need an exhaustive set of
checks because you're not testing that wal logging works properly,
just that the tests aren't accidentally passing because they're not
finding any interesting records.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Greg Stark | 2022-02-02 17:09:06 | Re: 2022-01 Commitfest | 
| Previous Message | Robert Haas | 2022-02-02 16:45:29 | Re: CREATEROLE and role ownership hierarchies |