pgsql: Fix assorted bugs in GIN's WAL replay logic.
| От | Tom Lane |
|---|---|
| Тема | pgsql: Fix assorted bugs in GIN's WAL replay logic. |
| Дата | |
| Msg-id | E1P5RRI-00007E-Hd@gemulon.postgresql.org обсуждение исходный текст |
| Список | pgsql-committers |
Fix assorted bugs in GIN's WAL replay logic. The original coding was quite sloppy about handling the case where XLogReadBuffer fails (because the page has since been deleted). This would result in either "bad buffer id: 0" or an Assert failure during replay, if indeed the page were no longer there. In a couple of places it also neglected to check whether the change had already been applied, which would probably result in corrupted index contents. I believe that bug #5703 is an instance of the first problem. These issues could show up without replication, but only if you were unfortunate enough to crash between modification of a GIN index and the next checkpoint. Back-patch to 8.2, which is as far back as GIN has WAL support. Branch ------ REL8_4_STABLE Details ------- http://git.postgresql.org/gitweb?p=postgresql.git;a=commitdiff;h=9dfd3086431b594f26026b7cfb91f56195aa30d7 Modified Files -------------- src/backend/access/gin/ginxlog.c | 308 ++++++++++++++++++++++---------------- 1 files changed, 181 insertions(+), 127 deletions(-)
В списке pgsql-committers по дате отправления: