Re: Alias collision in `refresh materialized view concurrently`

Поиск
Список
Период
Сортировка
От Bharath Rupireddy
Тема Re: Alias collision in `refresh materialized view concurrently`
Дата
Msg-id CALj2ACVaYYfzTc4jyFTRsnjyub37jVvdbGv=JMxKXGbLz_FcBA@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Alias collision in `refresh materialized view concurrently`  (Michael Paquier <michael@paquier.xyz>)
Ответы Re: Alias collision in `refresh materialized view concurrently`  (Michael Paquier <michael@paquier.xyz>)
Список pgsql-hackers
On Fri, May 21, 2021 at 6:08 AM Michael Paquier <michael@paquier.xyz> wrote:
>
> On Thu, May 20, 2021 at 09:14:45PM +0530, Bharath Rupireddy wrote:
> > On Thu, May 20, 2021 at 7:52 PM Bernd Helmle <mailings@oopsware.de> wrote:
> >> "mv" looks like a very common alias (i use it all over the time when
> >> testing or playing around with materialized views, so i'm wondering why
> >>  i didn't see this issue already myself). So the risk here for such a
> >>  collision looks very high. We can try to lower this risk by choosing an
> >>  alias name, which is not so common. With a static alias however you get
> >>  a static error condition, not something that fails here and then.
> >
> > Another idea is to use random() function to generate required number
> > of uint32 random values(refresh_by_match_merge might need 3 values to
> > replace newdata, newdata2 and mv) and use the names like
> > pg_temp_rmv_<<rand_no1>>,  pg_temp_rmv_<<rand_no2>> and so on. This
> > would make the name unguessable. Note that we use this in
> > choose_dsm_implementation, dsm_impl_posix.
>
> I am not sure that I see the point of using a random() number here
> while the backend ID, or just the PID, would easily provide enough
> entropy for this internal alias.  I agree that "mv" is a bad choice
> for this alias name.  One thing that comes in mind here is to use an
> alias similar to what we do for dropped attributes, say
> ........pg.matview.%d........ where %d is the PID.  This will very
> unlikely cause conflicts.

I agree that backend ID and/or PID is enough. I'm not fully convinced
with using random(). To make it more concrete, how about something
like pg.matview.%d.%d (MyBackendId, MyProcPid)? If the user still sees
some collisions, then IMHO, it's better to ensure that this kind of
table/alias names are not generated outside of the server.

With Regards,
Bharath Rupireddy.
EnterpriseDB: http://www.enterprisedb.com



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

Предыдущее
От: Amit Kapila
Дата:
Сообщение: Re: "ERROR: deadlock detected" when replicating TRUNCATE
Следующее
От: Bharath Rupireddy
Дата:
Сообщение: Re: Parallel Inserts in CREATE TABLE AS