- Notifications
You must be signed in to change notification settings - Fork5
Commitd1cbd26
committed
Repair two places where SIGTERM exit could leave shared memory state
corrupted. (Neither is very important if SIGTERM is used to shut down thewhole database cluster together, but there's a problem if someone tries toSIGTERM individual backends.) To do this, introduce new infrastructuremacros PG_ENSURE_ERROR_CLEANUP/PG_END_ENSURE_ERROR_CLEANUP that take careof transiently pushing an on_shmem_exit cleanup hook. Also use this methodfor createdb cleanup --- that wasn't a shared-memory-corruption problem,but SIGTERM abort of createdb could leave orphaned files lying around.Backpatch as far as 8.2. The shmem corruption cases don't exist in 8.1,and the createdb usage doesn't seem important enough to risk backpatchingfurther.1 parent74be868 commitd1cbd26
File tree
9 files changed
+153
-57
lines changed- src
- backend
- access
- nbtree
- transam
- commands
- port
- storage/ipc
- include
- access
- storage
- utils
9 files changed
+153
-57
lines changedLines changed: 6 additions & 11 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
12 | 12 |
| |
13 | 13 |
| |
14 | 14 |
| |
15 |
| - | |
| 15 | + | |
16 | 16 |
| |
17 | 17 |
| |
18 | 18 |
| |
| |||
24 | 24 |
| |
25 | 25 |
| |
26 | 26 |
| |
| 27 | + | |
27 | 28 |
| |
28 | 29 |
| |
29 | 30 |
| |
| |||
530 | 531 |
| |
531 | 532 |
| |
532 | 533 |
| |
533 |
| - | |
| 534 | + | |
| 535 | + | |
534 | 536 |
| |
535 | 537 |
| |
536 | 538 |
| |
537 | 539 |
| |
538 |
| - | |
539 |
| - | |
540 |
| - | |
541 |
| - | |
542 |
| - | |
543 |
| - | |
544 |
| - | |
545 |
| - | |
546 | 540 |
| |
547 |
| - | |
| 541 | + | |
| 542 | + | |
548 | 543 |
| |
549 | 544 |
| |
550 | 545 |
| |
|
Lines changed: 15 additions & 3 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
8 | 8 |
| |
9 | 9 |
| |
10 | 10 |
| |
11 |
| - | |
| 11 | + | |
12 | 12 |
| |
13 | 13 |
| |
14 | 14 |
| |
| |||
1252 | 1252 |
| |
1253 | 1253 |
| |
1254 | 1254 |
| |
1255 |
| - | |
1256 |
| - | |
| 1255 | + | |
| 1256 | + | |
| 1257 | + | |
| 1258 | + | |
| 1259 | + | |
1257 | 1260 |
| |
1258 | 1261 |
| |
1259 | 1262 |
| |
| |||
1337 | 1340 |
| |
1338 | 1341 |
| |
1339 | 1342 |
| |
| 1343 | + | |
| 1344 | + | |
| 1345 | + | |
| 1346 | + | |
| 1347 | + | |
| 1348 | + | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
1340 | 1352 |
| |
1341 | 1353 |
| |
1342 | 1354 |
| |
|
Lines changed: 17 additions & 15 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
7 | 7 |
| |
8 | 8 |
| |
9 | 9 |
| |
10 |
| - | |
| 10 | + | |
11 | 11 |
| |
12 | 12 |
| |
13 | 13 |
| |
| |||
43 | 43 |
| |
44 | 44 |
| |
45 | 45 |
| |
| 46 | + | |
46 | 47 |
| |
47 | 48 |
| |
48 | 49 |
| |
| |||
419 | 420 |
| |
420 | 421 |
| |
421 | 422 |
| |
422 |
| - | |
423 |
| - | |
424 | 423 |
| |
425 | 424 |
| |
426 | 425 |
| |
| 426 | + | |
| 427 | + | |
427 | 428 |
| |
428 | 429 |
| |
429 | 430 |
| |
| |||
6442 | 6443 |
| |
6443 | 6444 |
| |
6444 | 6445 |
| |
6445 |
| - | |
6446 |
| - | |
| 6446 | + | |
| 6447 | + | |
6447 | 6448 |
| |
6448 | 6449 |
| |
6449 | 6450 |
| |
| |||
6515 | 6516 |
| |
6516 | 6517 |
| |
6517 | 6518 |
| |
6518 |
| - | |
6519 |
| - | |
6520 |
| - | |
6521 |
| - | |
6522 |
| - | |
6523 |
| - | |
6524 |
| - | |
6525 |
| - | |
6526 |
| - | |
6527 |
| - | |
| 6519 | + | |
6528 | 6520 |
| |
6529 | 6521 |
| |
6530 | 6522 |
| |
| |||
6534 | 6526 |
| |
6535 | 6527 |
| |
6536 | 6528 |
| |
| 6529 | + | |
| 6530 | + | |
| 6531 | + | |
| 6532 | + | |
| 6533 | + | |
| 6534 | + | |
| 6535 | + | |
| 6536 | + | |
| 6537 | + | |
| 6538 | + | |
6537 | 6539 |
| |
6538 | 6540 |
| |
6539 | 6541 |
| |
|
Lines changed: 32 additions & 13 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
13 | 13 |
| |
14 | 14 |
| |
15 | 15 |
| |
16 |
| - | |
| 16 | + | |
17 | 17 |
| |
18 | 18 |
| |
19 | 19 |
| |
| |||
41 | 41 |
| |
42 | 42 |
| |
43 | 43 |
| |
| 44 | + | |
44 | 45 |
| |
45 | 46 |
| |
46 | 47 |
| |
| |||
53 | 54 |
| |
54 | 55 |
| |
55 | 56 |
| |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
56 | 63 |
| |
| 64 | + | |
57 | 65 |
| |
58 | 66 |
| |
59 | 67 |
| |
| |||
99 | 107 |
| |
100 | 108 |
| |
101 | 109 |
| |
| 110 | + | |
102 | 111 |
| |
103 | 112 |
| |
104 | 113 |
| |
| |||
449 | 458 |
| |
450 | 459 |
| |
451 | 460 |
| |
452 |
| - | |
| 461 | + | |
453 | 462 |
| |
454 | 463 |
| |
455 | 464 |
| |
456 | 465 |
| |
457 |
| - | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
458 | 470 |
| |
459 | 471 |
| |
460 | 472 |
| |
| |||
565 | 577 |
| |
566 | 578 |
| |
567 | 579 |
| |
568 |
| - | |
569 |
| - | |
570 |
| - | |
571 |
| - | |
572 |
| - | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
573 | 589 |
| |
574 |
| - | |
575 |
| - | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
576 | 596 |
| |
577 |
| - | |
578 |
| - | |
579 |
| - | |
| 597 | + | |
| 598 | + | |
580 | 599 |
| |
581 | 600 |
| |
582 | 601 |
| |
|
Lines changed: 6 additions & 6 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
21 | 21 |
| |
22 | 22 |
| |
23 | 23 |
| |
24 |
| - | |
| 24 | + | |
25 | 25 |
| |
26 | 26 |
| |
27 | 27 |
| |
| |||
58 | 58 |
| |
59 | 59 |
| |
60 | 60 |
| |
61 |
| - | |
| 61 | + | |
62 | 62 |
| |
63 | 63 |
| |
64 | 64 |
| |
| |||
85 | 85 |
| |
86 | 86 |
| |
87 | 87 |
| |
88 |
| - | |
| 88 | + | |
89 | 89 |
| |
90 | 90 |
| |
91 | 91 |
| |
| |||
114 | 114 |
| |
115 | 115 |
| |
116 | 116 |
| |
117 |
| - | |
118 |
| - | |
119 |
| - | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
120 | 120 |
| |
121 | 121 |
| |
122 | 122 |
| |
|
Lines changed: 22 additions & 4 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
13 | 13 |
| |
14 | 14 |
| |
15 | 15 |
| |
16 |
| - | |
| 16 | + | |
17 | 17 |
| |
18 | 18 |
| |
19 | 19 |
| |
| |||
56 | 56 |
| |
57 | 57 |
| |
58 | 58 |
| |
59 |
| - | |
| 59 | + | |
60 | 60 |
| |
61 | 61 |
| |
62 | 62 |
| |
| |||
184 | 184 |
| |
185 | 185 |
| |
186 | 186 |
| |
187 |
| - | |
| 187 | + | |
188 | 188 |
| |
189 | 189 |
| |
190 | 190 |
| |
| |||
205 | 205 |
| |
206 | 206 |
| |
207 | 207 |
| |
208 |
| - | |
| 208 | + | |
209 | 209 |
| |
210 | 210 |
| |
211 | 211 |
| |
| |||
218 | 218 |
| |
219 | 219 |
| |
220 | 220 |
| |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
221 | 239 |
| |
222 | 240 |
| |
223 | 241 |
| |
|
Lines changed: 2 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
7 | 7 |
| |
8 | 8 |
| |
9 | 9 |
| |
10 |
| - | |
| 10 | + | |
11 | 11 |
| |
12 | 12 |
| |
13 | 13 |
| |
| |||
574 | 574 |
| |
575 | 575 |
| |
576 | 576 |
| |
| 577 | + | |
577 | 578 |
| |
578 | 579 |
| |
579 | 580 |
| |
|
0 commit comments
Comments
(0)