- Notifications
You must be signed in to change notification settings - Fork5
Commit8fad2e3
committed
Arrange for GetSnapshotData to copy live-subtransaction XIDs from the
PGPROC array into snapshots, and use this information to avoid visitsto pg_subtrans in HeapTupleSatisfiesSnapshot. This appears to solvethe pg_subtrans-related context swap storm problem that's been reportedby several people for 8.1. While at it, modify GetSnapshotData to nottake an exclusive lock on ProcArrayLock, as closer analysis shows thatshared lock is always sufficient.Itagaki Takahiro and Tom Lane1 parentf79f57a commit8fad2e3
File tree
4 files changed
+183
-83
lines changed- src
- backend
- access/transam
- storage/ipc
- utils/time
- include/utils
4 files changed
+183
-83
lines changedLines changed: 17 additions & 6 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
6 | 6 |
| |
7 | 7 |
| |
8 | 8 |
| |
9 |
| - | |
| 9 | + | |
10 | 10 |
| |
11 | 11 |
| |
12 | 12 |
| |
| |||
131 | 131 |
| |
132 | 132 |
| |
133 | 133 |
| |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
134 | 143 |
| |
135 |
| - | |
| 144 | + | |
136 | 145 |
| |
137 | 146 |
| |
138 |
| - | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
139 | 150 |
| |
140 |
| - | |
141 |
| - | |
| 151 | + | |
| 152 | + | |
142 | 153 |
| |
143 | 154 |
| |
144 |
| - | |
| 155 | + | |
145 | 156 |
| |
146 | 157 |
| |
147 | 158 |
| |
|
Lines changed: 59 additions & 10 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
23 | 23 |
| |
24 | 24 |
| |
25 | 25 |
| |
26 |
| - | |
| 26 | + | |
27 | 27 |
| |
28 | 28 |
| |
29 | 29 |
| |
| |||
475 | 475 |
| |
476 | 476 |
| |
477 | 477 |
| |
478 |
| - | |
479 |
| - | |
480 |
| - | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
481 | 484 |
| |
482 | 485 |
| |
483 | 486 |
| |
| |||
499 | 502 |
| |
500 | 503 |
| |
501 | 504 |
| |
| 505 | + | |
502 | 506 |
| |
503 | 507 |
| |
504 | 508 |
| |
| |||
510 | 514 |
| |
511 | 515 |
| |
512 | 516 |
| |
513 |
| - | |
| 517 | + | |
| 518 | + | |
514 | 519 |
| |
515 | 520 |
| |
516 | 521 |
| |
517 |
| - | |
| 522 | + | |
518 | 523 |
| |
519 | 524 |
| |
520 | 525 |
| |
| |||
528 | 533 |
| |
529 | 534 |
| |
530 | 535 |
| |
| 536 | + | |
| 537 | + | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
531 | 543 |
| |
532 | 544 |
| |
533 | 545 |
| |
534 | 546 |
| |
535 | 547 |
| |
536 |
| - | |
537 |
| - | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
538 | 557 |
| |
539 |
| - | |
| 558 | + | |
540 | 559 |
| |
541 | 560 |
| |
542 | 561 |
| |
| |||
599 | 618 |
| |
600 | 619 |
| |
601 | 620 |
| |
| 621 | + | |
| 622 | + | |
| 623 | + | |
| 624 | + | |
| 625 | + | |
| 626 | + | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
| 636 | + | |
| 637 | + | |
| 638 | + | |
| 639 | + | |
| 640 | + | |
| 641 | + | |
| 642 | + | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
602 | 650 |
| |
603 | 651 |
| |
604 | 652 |
| |
| |||
621 | 669 |
| |
622 | 670 |
| |
623 | 671 |
| |
| 672 | + | |
624 | 673 |
| |
625 | 674 |
| |
626 | 675 |
| |
| |||
862 | 911 |
| |
863 | 912 |
| |
864 | 913 |
| |
865 |
| - | |
| 914 | + | |
866 | 915 |
| |
867 | 916 |
| |
868 | 917 |
| |
|
Lines changed: 100 additions & 66 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
32 | 32 |
| |
33 | 33 |
| |
34 | 34 |
| |
35 |
| - | |
| 35 | + | |
36 | 36 |
| |
37 | 37 |
| |
38 | 38 |
| |
| |||
72 | 72 |
| |
73 | 73 |
| |
74 | 74 |
| |
| 75 | + | |
| 76 | + | |
| 77 | + | |
75 | 78 |
| |
76 | 79 |
| |
77 | 80 |
| |
| |||
943 | 946 |
| |
944 | 947 |
| |
945 | 948 |
| |
946 |
| - | |
947 |
| - | |
948 |
| - | |
949 |
| - | |
950 |
| - | |
951 |
| - | |
952 |
| - | |
953 | 949 |
| |
954 |
| - | |
955 |
| - | |
956 |
| - | |
957 |
| - | |
958 |
| - | |
959 |
| - | |
960 |
| - | |
961 |
| - | |
962 |
| - | |
963 |
| - | |
964 |
| - | |
965 |
| - | |
966 |
| - | |
967 |
| - | |
968 |
| - | |
969 |
| - | |
970 |
| - | |
971 |
| - | |
972 |
| - | |
973 |
| - | |
974 |
| - | |
975 |
| - | |
976 |
| - | |
977 |
| - | |
| 950 | + | |
| 951 | + | |
978 | 952 |
| |
979 | 953 |
| |
980 | 954 |
| |
| |||
1017 | 991 |
| |
1018 | 992 |
| |
1019 | 993 |
| |
1020 |
| - | |
1021 |
| - | |
1022 | 994 |
| |
1023 |
| - | |
1024 |
| - | |
1025 |
| - | |
1026 |
| - | |
| 995 | + | |
| 996 | + | |
1027 | 997 |
| |
1028 |
| - | |
1029 |
| - | |
1030 |
| - | |
1031 |
| - | |
1032 |
| - | |
1033 |
| - | |
1034 |
| - | |
1035 |
| - | |
1036 |
| - | |
1037 |
| - | |
1038 |
| - | |
1039 |
| - | |
1040 |
| - | |
1041 |
| - | |
1042 |
| - | |
1043 |
| - | |
1044 |
| - | |
1045 |
| - | |
1046 |
| - | |
1047 |
| - | |
1048 |
| - | |
1049 |
| - | |
1050 | 998 |
| |
1051 |
| - | |
1052 |
| - | |
1053 |
| - | |
1054 | 999 |
| |
1055 | 1000 |
| |
1056 | 1001 |
| |
| |||
1299 | 1244 |
| |
1300 | 1245 |
| |
1301 | 1246 |
| |
| 1247 | + | |
| 1248 | + | |
1302 | 1249 |
| |
1303 |
| - | |
1304 |
| - | |
1305 |
| - | |
| 1250 | + | |
| 1251 | + | |
| 1252 | + | |
| 1253 | + | |
| 1254 | + | |
| 1255 | + | |
| 1256 | + | |
1306 | 1257 |
| |
| 1258 | + | |
| 1259 | + | |
1307 | 1260 |
| |
1308 | 1261 |
| |
1309 | 1262 |
| |
| |||
1313 | 1266 |
| |
1314 | 1267 |
| |
1315 | 1268 |
| |
| 1269 | + | |
| 1270 | + | |
| 1271 | + | |
| 1272 | + | |
| 1273 | + | |
| 1274 | + | |
| 1275 | + | |
| 1276 | + | |
| 1277 | + | |
| 1278 | + | |
1316 | 1279 |
| |
1317 | 1280 |
| |
1318 | 1281 |
| |
| |||
1347 | 1310 |
| |
1348 | 1311 |
| |
1349 | 1312 |
| |
| 1313 | + | |
| 1314 | + | |
| 1315 | + | |
| 1316 | + | |
| 1317 | + | |
| 1318 | + | |
| 1319 | + | |
| 1320 | + | |
| 1321 | + | |
| 1322 | + | |
| 1323 | + | |
| 1324 | + | |
| 1325 | + | |
| 1326 | + | |
| 1327 | + | |
| 1328 | + | |
| 1329 | + | |
| 1330 | + | |
| 1331 | + | |
| 1332 | + | |
| 1333 | + | |
| 1334 | + | |
| 1335 | + | |
| 1336 | + | |
| 1337 | + | |
| 1338 | + | |
| 1339 | + | |
| 1340 | + | |
| 1341 | + | |
| 1342 | + | |
| 1343 | + | |
| 1344 | + | |
| 1345 | + | |
| 1346 | + | |
| 1347 | + | |
| 1348 | + | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
| 1352 | + | |
| 1353 | + | |
| 1354 | + | |
| 1355 | + | |
| 1356 | + | |
| 1357 | + | |
| 1358 | + | |
| 1359 | + | |
| 1360 | + | |
| 1361 | + | |
| 1362 | + | |
| 1363 | + | |
| 1364 | + | |
| 1365 | + | |
| 1366 | + | |
| 1367 | + | |
| 1368 | + | |
| 1369 | + | |
| 1370 | + | |
| 1371 | + | |
| 1372 | + | |
| 1373 | + | |
| 1374 | + | |
| 1375 | + | |
| 1376 | + | |
| 1377 | + | |
| 1378 | + | |
| 1379 | + | |
| 1380 | + | |
| 1381 | + | |
| 1382 | + | |
| 1383 | + |
0 commit comments
Comments
(0)