Jan Wieck <j...@wi3ck.info> writes: > On 3/8/21 11:58 AM, Tom Lane wrote: >> So it seems like the path of least resistance is >> (a) make pg_upgrade use --single-transaction when calling pg_restore >> (b) document (better) how to get around too-many-locks failures.
> That would first require to fix how pg_upgrade is creating the > databases. It uses "pg_restore --create", which is mutually exclusive > with --single-transaction because we cannot create a database inside of > a transaction. Ugh. > All that aside, the entire approach doesn't scale. Yeah, agreed. When we gave large objects individual ownership and ACL info, it was argued that pg_dump could afford to treat each one as a separate TOC entry because "you wouldn't have that many of them, if they're large". The limits of that approach were obvious even at the time, and I think now we're starting to see people for whom it really doesn't work. I wonder if pg_dump could improve matters cheaply by aggregating the large objects by owner and ACL contents. That is, do select distinct lomowner, lomacl from pg_largeobject_metadata; and make just *one* BLOB TOC entry for each result. Then dump out all the matching blobs under that heading. A possible objection is that it'd reduce the ability to restore blobs selectively, so maybe we'd need to make it optional. Of course, that just reduces the memory consumption on the client side; it does nothing for the locks. Can we get away with releasing the lock immediately after doing an ALTER OWNER or GRANT/REVOKE on a blob? regards, tom lane