Re: REINDEX locking
| От | Peter Geoghegan | 
|---|---|
| Тема | Re: REINDEX locking | 
| Дата | |
| Msg-id | CAH2-Wz=pHkr5vGMf2=KUiJsfJ1YEyg1jkKYUu09RabQd7wBkjQ@mail.gmail.com обсуждение исходный текст | 
| Ответ на | REINDEX locking (Robert Haas <robertmhaas@gmail.com>) | 
| Список | pgsql-hackers | 
On Thu, Jun 13, 2019 at 1:04 PM Robert Haas <robertmhaas@gmail.com> wrote: > Typing "COMMIT;" or "ROLLBACK;" in S1 unblocks the reindex and it > succeeds, but otherwise it doesn't, contrary to the claim that a > regular REINDEX does not block reads. The reason for this seems to be > that the REINDEX acquires AccessExclusiveLock on all of the indexes of > the table, and a SELECT acquires AccessShareLock on all indexes of the > table (even if the particular plan at issue does not use them); e.g. > in this case the plan is a Seq Scan. REINDEX acquires only ShareLock > on the table itself, but this apparently does nobody wanting to run a > query any good. > > Is it supposed to work this way? Am I confused? I've always thought that this framing was very user-hostile. Theoretically, REINDEX doesn't have to block reads (e.g. it won't with prepared statements when various conditions are met), but in practice the behavior isn't meaningfully different from blocking reads. -- Peter Geoghegan
В списке pgsql-hackers по дате отправления: