Re: ResourceOwner refactoring

Поиск
Список
Период
Сортировка
От Heikki Linnakangas
Тема Re: ResourceOwner refactoring
Дата
Msg-id 1377f062-13ea-ebfb-ef8a-97739c156a05@iki.fi
обсуждение исходный текст
Ответ на Re: ResourceOwner refactoring  (Aleksander Alekseev <aleksander@timescale.com>)
Ответы Re: ResourceOwner refactoring  (Aleksander Alekseev <aleksander@timescale.com>)
Список pgsql-hackers
On 08/09/2021 13:19, Aleksander Alekseev wrote:
> Hi Heikki,
> 
>> Yeah, needed some manual fixing, but here you go.
> 
> Thanks for working on this!
> 
> v8-0002 didn't apply to the current master, so I rebased it. See
> attached v9-* patches. I also included v9-0004 with some minor tweaks
> from me. I have several notes regarding the code.

Thanks!

Attached is a newly rebased version. It includes your tweaks, and a few 
more comment and indentation tweaks.

> 1. Not sure if I understand this code of ResourceOwnerReleaseAll():
> ```
>      /* First handle all the entries in the array. */
>      do
>      {
>          found = false;
>          for (int i = 0; i < owner->narr; i++)
>          {
>              if (owner->arr[i].kind->phase == phase)
>              {
>                  Datum        value = owner->arr[i].item;
>                  ResourceOwnerFuncs *kind = owner->arr[i].kind;
> 
>                  if (printLeakWarnings)
>                      kind->PrintLeakWarning(value);
>                  kind->ReleaseResource(value);
>                  found = true;
>              }
>          }
> 
>          /*
>           * If any resources were released, check again because some of the
>           * elements might have been moved by the callbacks. We don't want to
>           * miss them.
>           */
>      } while (found && owner->narr > 0);
> ```
> 
> Shouldn't we mark the resource as released and/or decrease narr and/or
> save the last processed i? Why this will not call ReleaseResource()
> endlessly on the same resource (array item)? Same question for the
> following code that iterates over the hash table.

ReleaseResource() must call ResourceOwnerForget(), which removes the 
item from the or hash table. This works the same as the code in 'master':

>         /*
>          * Release buffer pins.  Note that ReleaseBuffer will remove the
>          * buffer entry from our array, so we just have to iterate till there
>          * are none.
>          *
>          * During a commit, there shouldn't be any remaining pins --- that
>          * would indicate failure to clean up the executor correctly --- so
>          * issue warnings.  In the abort case, just clean up quietly.
>          */
>         while (ResourceArrayGetAny(&(owner->bufferarr), &foundres))
>         {
>             Buffer        res = DatumGetBuffer(foundres);
> 
>             if (isCommit)
>                 PrintBufferLeakWarning(res);
>             ReleaseBuffer(res);
>         }

That comment explains how it works. I added a comment like that in this 
patch, too.

> 2. Just an idea/observation. It's possible that the performance of
> ResourceOwnerEnlarge() can be slightly improved. Since the size of the
> hash table is always a power of 2 and the code always doubles the size
> of the hash table, (idx & mask) value will get one extra bit, which
> can be 0 or 1. If it's 0, the value is already in its place,
> otherwise, it should be moved on the known distance. In other words,
> it's possible to copy `oldhash` to `newhash` and then move only half
> of the items. I don't claim that this code necessarily should be
> faster, or that this should be checked in the scope of this work.

Hmm, the hash table uses open addressing, I think we want to also 
rearrange any existing entries that might not be at their right place 
because of collisions. We don't actually do that currently when an 
element is removed (even before this patch), but enlarging the array is 
a good opportunity for it. In any case, I haven't seen 
ResourceOwnerEnlarge() show up while profiling, so I'm going to leave it 
as it is.

- Heikki

Вложения

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

Предыдущее
От: Amit Kapila
Дата:
Сообщение: Re: relation OID in ReorderBufferToastReplace error message
Следующее
От: wenjing
Дата:
Сообщение: Re: [Proposal] Global temporary tables