mirror of
https://github.com/postgres/postgres.git
synced 2025-11-10 17:42:29 +03:00
Improve Asserts checking relation matching in parallel scans.
table_beginscan_parallel and index_beginscan_parallel contain
Asserts checking that the relation a worker will use in
a parallel scan is the same one the leader intended. However,
they were checking for relation OID match, which was not strong
enough to detect the mismatch problem fixed in 126ec0bc7.
What would be strong enough is to compare relfilenodes instead.
Arguably, that's a saner definition anyway, since a scan surely
operates on a physical relation not a logical one. Hence,
store and compare RelFileLocators not relation OIDs. Also
ensure that index_beginscan_parallel checks the index identity
not just the table identity.
Discussion: https://postgr.es/m/2127254.1726789524@sss.pgh.pa.us
This commit is contained in:
@@ -168,7 +168,7 @@ table_beginscan_parallel(Relation relation, ParallelTableScanDesc pscan)
|
||||
uint32 flags = SO_TYPE_SEQSCAN |
|
||||
SO_ALLOW_STRAT | SO_ALLOW_SYNC | SO_ALLOW_PAGEMODE;
|
||||
|
||||
Assert(RelationGetRelid(relation) == pscan->phs_relid);
|
||||
Assert(RelFileLocatorEquals(relation->rd_locator, pscan->phs_locator));
|
||||
|
||||
if (!pscan->phs_snapshot_any)
|
||||
{
|
||||
@@ -389,7 +389,7 @@ table_block_parallelscan_initialize(Relation rel, ParallelTableScanDesc pscan)
|
||||
{
|
||||
ParallelBlockTableScanDesc bpscan = (ParallelBlockTableScanDesc) pscan;
|
||||
|
||||
bpscan->base.phs_relid = RelationGetRelid(rel);
|
||||
bpscan->base.phs_locator = rel->rd_locator;
|
||||
bpscan->phs_nblocks = RelationGetNumberOfBlocks(rel);
|
||||
/* compare phs_syncscan initialization to similar logic in initscan */
|
||||
bpscan->base.phs_syncscan = synchronize_seqscans &&
|
||||
|
||||
Reference in New Issue
Block a user