]> granicus.if.org Git - postgresql/commitdiff
Fix identify_locking_dependencies for schema-only dumps.
authorRobert Haas <rhaas@postgresql.org>
Fri, 26 Sep 2014 15:21:35 +0000 (11:21 -0400)
committerRobert Haas <rhaas@postgresql.org>
Fri, 26 Sep 2014 15:43:56 +0000 (11:43 -0400)
Without this fix, parallel restore of a schema-only dump can deadlock,
because when the dump is schema-only, the dependency will still be
pointing at the TABLE item rather than the TABLE DATA item.

Robert Haas and Tom Lane

src/bin/pg_dump/pg_backup_archiver.c

index d3f12430dd3789e26d72754bc3bbb80518ea6914..a0011dc9be1b66d6e7e1585920281d247d3ab8d1 100644 (file)
@@ -4085,11 +4085,14 @@ identify_locking_dependencies(TocEntry *te)
                return;
 
        /*
-        * We assume the item requires exclusive lock on each TABLE DATA item
-        * listed among its dependencies.  (This was originally a dependency on
-        * the TABLE, but fix_dependencies repointed it to the data item. Note
-        * that all the entry types we are interested in here are POST_DATA, so
-        * they will all have been changed this way.)
+        * We assume the entry requires exclusive lock on each TABLE or TABLE DATA
+        * item listed among its dependencies.  Originally all of these would have
+        * been TABLE items, but repoint_table_dependencies would have repointed
+        * them to the TABLE DATA items if those are present (which they might not
+        * be, eg in a schema-only dump).  Note that all of the entries we are
+        * processing here are POST_DATA; otherwise there might be a significant
+        * difference between a dependency on a table and a dependency on its
+        * data, so that closer analysis would be needed here.
         */
        lockids = (DumpId *) malloc(te->nDeps * sizeof(DumpId));
        nlockids = 0;
@@ -4098,7 +4101,8 @@ identify_locking_dependencies(TocEntry *te)
                DumpId          depid = te->dependencies[i];
 
                if (depid <= maxDumpId && tocsByDumpId[depid - 1] &&
-                       strcmp(tocsByDumpId[depid - 1]->desc, "TABLE DATA") == 0)
+                       ((strcmp(tocsByDumpId[depid - 1]->desc, "TABLE DATA") == 0) ||
+                         strcmp(tocsByDumpId[depid - 1]->desc, "TABLE") == 0))
                        lockids[nlockids++] = depid;
        }