forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commit1d65416
committed
Improve handling of dropped relations for REINDEX DATABASE/SCHEMA/SYSTEM
When multiple relations are reindexed, a scan of pg_class is done firstto build the list of relations to work on. However the REINDEX logichas never checked if a relation listed still exists when beginning thework on it, causing for example sudden cache lookup failures.This commit adds safeguards against dropped relations for REINDEX,similarly to VACUUM or CLUSTER where we try to open the relation,ignoring it if it is missing. A new option is added to the REINDEXroutines to control if a missed relation is OK to ignore or not.An isolation test, based on REINDEX SCHEMA, is added for the concurrentand non-concurrent cases.Author: Michael PaquierReviewed-by: Anastasia LubennikovaDiscussion:https://postgr.es/m/20200813043805.GE11663@paquier.xyz1 parent4c51a2d commit1d65416
File tree
8 files changed
+174
-9
lines changed- src
- backend
- access/table
- catalog
- commands
- include
- access
- nodes
- test/isolation
- expected
- specs
8 files changed
+174
-9
lines changedLines changed: 34 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
57 | 57 |
| |
58 | 58 |
| |
59 | 59 |
| |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
60 | 94 |
| |
61 | 95 |
| |
62 | 96 |
| |
|
Lines changed: 30 additions & 4 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
3437 | 3437 |
| |
3438 | 3438 |
| |
3439 | 3439 |
| |
3440 |
| - | |
3441 |
| - | |
| 3440 | + | |
| 3441 | + | |
| 3442 | + | |
| 3443 | + | |
| 3444 | + | |
| 3445 | + | |
| 3446 | + | |
| 3447 | + | |
| 3448 | + | |
| 3449 | + | |
| 3450 | + | |
| 3451 | + | |
| 3452 | + | |
| 3453 | + | |
3442 | 3454 |
| |
3443 | 3455 |
| |
3444 | 3456 |
| |
| |||
3672 | 3684 |
| |
3673 | 3685 |
| |
3674 | 3686 |
| |
3675 |
| - | |
| 3687 | + | |
| 3688 | + | |
| 3689 | + | |
| 3690 | + | |
| 3691 | + | |
| 3692 | + | |
| 3693 | + | |
| 3694 | + | |
3676 | 3695 |
| |
3677 | 3696 |
| |
3678 | 3697 |
| |
| |||
3771 | 3790 |
| |
3772 | 3791 |
| |
3773 | 3792 |
| |
3774 |
| - | |
| 3793 | + | |
| 3794 | + | |
| 3795 | + | |
| 3796 | + | |
| 3797 | + | |
| 3798 | + | |
| 3799 | + | |
| 3800 | + | |
3775 | 3801 |
| |
3776 | 3802 |
| |
3777 | 3803 |
| |
|
Lines changed: 58 additions & 5 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
2766 | 2766 |
| |
2767 | 2767 |
| |
2768 | 2768 |
| |
| 2769 | + | |
| 2770 | + | |
| 2771 | + | |
| 2772 | + | |
| 2773 | + | |
| 2774 | + | |
| 2775 | + | |
| 2776 | + | |
2769 | 2777 |
| |
2770 | 2778 |
| |
2771 |
| - | |
| 2779 | + | |
| 2780 | + | |
| 2781 | + | |
2772 | 2782 |
| |
2773 | 2783 |
| |
2774 | 2784 |
| |
| |||
2778 | 2788 |
| |
2779 | 2789 |
| |
2780 | 2790 |
| |
2781 |
| - | |
| 2791 | + | |
| 2792 | + | |
| 2793 | + | |
2782 | 2794 |
| |
2783 | 2795 |
| |
2784 | 2796 |
| |
| |||
2893 | 2905 |
| |
2894 | 2906 |
| |
2895 | 2907 |
| |
2896 |
| - | |
| 2908 | + | |
| 2909 | + | |
| 2910 | + | |
| 2911 | + | |
| 2912 | + | |
| 2913 | + | |
| 2914 | + | |
| 2915 | + | |
| 2916 | + | |
| 2917 | + | |
| 2918 | + | |
2897 | 2919 |
| |
2898 | 2920 |
| |
2899 | 2921 |
| |
| |||
2978 | 3000 |
| |
2979 | 3001 |
| |
2980 | 3002 |
| |
2981 |
| - | |
| 3003 | + | |
| 3004 | + | |
| 3005 | + | |
| 3006 | + | |
| 3007 | + | |
| 3008 | + | |
| 3009 | + | |
2982 | 3010 |
| |
2983 | 3011 |
| |
2984 | 3012 |
| |
| |||
2995 | 3023 |
| |
2996 | 3024 |
| |
2997 | 3025 |
| |
| 3026 | + | |
| 3027 | + | |
| 3028 | + | |
| 3029 | + | |
| 3030 | + | |
| 3031 | + | |
| 3032 | + | |
| 3033 | + | |
| 3034 | + | |
| 3035 | + | |
| 3036 | + | |
| 3037 | + | |
| 3038 | + | |
| 3039 | + | |
| 3040 | + | |
| 3041 | + | |
| 3042 | + | |
| 3043 | + | |
| 3044 | + | |
2998 | 3045 |
| |
2999 | 3046 |
| |
3000 | 3047 |
| |
| |||
3025 | 3072 |
| |
3026 | 3073 |
| |
3027 | 3074 |
| |
3028 |
| - | |
| 3075 | + | |
| 3076 | + | |
| 3077 | + | |
| 3078 | + | |
| 3079 | + | |
| 3080 | + | |
| 3081 | + | |
3029 | 3082 |
| |
3030 | 3083 |
| |
3031 | 3084 |
| |
|
Lines changed: 1 addition & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
22 | 22 |
| |
23 | 23 |
| |
24 | 24 |
| |
| 25 | + | |
25 | 26 |
| |
26 | 27 |
| |
27 | 28 |
|
Lines changed: 1 addition & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
3352 | 3352 |
| |
3353 | 3353 |
| |
3354 | 3354 |
| |
| 3355 | + | |
3355 | 3356 |
| |
3356 | 3357 |
| |
3357 | 3358 |
| |
|
Lines changed: 17 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 | + |
Lines changed: 1 addition & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
49 | 49 |
| |
50 | 50 |
| |
51 | 51 |
| |
| 52 | + | |
52 | 53 |
| |
53 | 54 |
| |
54 | 55 |
| |
|
Lines changed: 32 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 | + |
0 commit comments
Comments
(0)