On 2019-Jun-07, Peter Geoghegan wrote: > On Fri, Jun 7, 2019 at 12:18 PM Alvaro Herrera <alvherre@xxxxxxxxxxxxxxx> wrote: > > I was thinking of asynchonously cleaning it up rather than blocking > > DROP/DETACH ... which means you need to keep state somewhere. I don't > > think blocking DROP/DETACH is valuable -- a global index that blocks > > DROP/DETACH until the index is clean serves no useful purpose. (You > > could think of a multi-step approach with internal transaction commits, > > similar to CIC, but you still need a plan to clean that up in case the > > server crashes during that operation.) > > The advantage of synchronous clean-up of global indexes when DROP'ing > a partition are that you can recycle the partition number (or whatever > we end up calling it) immediately and predictably, and you can reuse > the space in indexes occupied by keys from the dropped partition > immediately and predictably. That seems less useful than asynchronous > processing on average, certainly, but those are still real advantages. > You seemed to be particularly concerned about quickly recycling > partition numbers when we drop a partition. Well, "quickly" might mean within a week. If it takes that long to fully remove a monthly partition to make that partition ID available to some future month's partition, that seems acceptable. Blocking DROP/DETACH for one hour is certainly not acceptable. If this scheme means that you can keep the partition identifiers stored in the index to, for instance, 10 bits (allowing for 1024 partitions to exist at any one time, including those in the process of being cleaned up) instead of having to expand to (say) 24 because that covers a couple of years of operation before having to recreate the index, it seems worthwhile. -- Álvaro Herrera https://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services