Re: Missing dependency tracking for TableFunc nodes

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Missing dependency tracking for TableFunc nodes
Дата
Msg-id 17008.1573770906@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: Missing dependency tracking for TableFunc nodes  (Tomas Vondra <tomas.vondra@2ndquadrant.com>)
Ответы Re: Missing dependency tracking for TableFunc nodes
Список pgsql-hackers
Tomas Vondra <tomas.vondra@2ndquadrant.com> writes:
> On Thu, Nov 14, 2019 at 04:36:54PM -0500, Tom Lane wrote:
>> Hm.  No, it's not enough, unless you add more logic to deal with the
>> possibility that the stats object is gone by the time you have the
>> table lock.  Consider e.g. two concurrent DROP STATISTICS commands,
>> or a statistics drop that's cascading from something like a drop
>> of a relevant function and so has no earlier table lock.

> Isn't that solved by RemoveObjects() doing this?

>     /* Get an ObjectAddress for the object. */
>     address = get_object_address(stmt->removeType,
>                                  object,
>                                  &relation,
>                                  AccessExclusiveLock,
>                                  stmt->missing_ok);

Ah, I see, we already have AEL on the stats object itself.  So that
eliminates my concern about a race between two RemoveStatisticsById
calls, but what we have instead is fear of deadlock.  A DROP STATISTICS
command will acquire AEL on the stats object but then AEL on the table,
the opposite of what will happen during DROP TABLE, so concurrent
executions of those will deadlock.  That might be better than the
failures Mark is seeing now, but not by much.

A correct fix I think is that the planner ought to acquire AccessShareLock
on a stats object it's trying to use (and then recheck whether the object
is still there).  That seems rather expensive, but there may be no other
way.

            regards, tom lane



В списке pgsql-hackers по дате отправления:

Предыдущее
От: Alvaro Herrera
Дата:
Сообщение: Re: Missing dependency tracking for TableFunc nodes
Следующее
От: Tom Lane
Дата:
Сообщение: Re: format of pg_upgrade loadable_libraries warning