forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commitab28fea
committed
Handle heap rewrites better in logical replication
A FOR ALL TABLES publication naturally considers all base tables to be acandidate for replication. This includes transient heaps that arecreated during a table rewrite during DDL. This causes failures on thesubscriber side because it will not have a table like pg_temp_16386 toreceive data (and if it did, it would be the wrong table).The prevent this problem, we filter out any tables that match thisnaming pattern and match an actual table from FOR ALL TABLESpublications. This is only a heuristic, meaning that user tables thatmatch that naming could accidentally be omitted. A more robust solutionmight require an explicit marking of such tables in pg_class somehow.Reported-by: yxq <yxq@o2.pl>Bug: #14785Reviewed-by: Andres Freund <andres@anarazel.de>Reviewed-by: Petr Jelinek <petr.jelinek@2ndquadrant.com>1 parent22c5e73 commitab28fea
File tree
2 files changed
+99
-0
lines changed- src
- backend/replication/pgoutput
- test/subscription/t
2 files changed
+99
-0
lines changedLines changed: 26 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
21 | 21 |
| |
22 | 22 |
| |
23 | 23 |
| |
| 24 | + | |
24 | 25 |
| |
25 | 26 |
| |
26 | 27 |
| |
| |||
509 | 510 |
| |
510 | 511 |
| |
511 | 512 |
| |
| 513 | + | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | + | |
512 | 538 |
| |
513 | 539 |
| |
514 | 540 |
| |
|
Lines changed: 73 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + |
0 commit comments
Comments
(0)