From: | Fujii Masao <masao(dot)fujii(at)oss(dot)nttdata(dot)com> |
---|---|
To: | Kyotaro Horiguchi <horikyota(dot)ntt(at)gmail(dot)com> |
Cc: | alvherre(at)2ndquadrant(dot)com, pgsql-hackers(at)lists(dot)postgresql(dot)org |
Subject: | Re: Review for GetWALAvailability() |
Date: | 2020-06-18 05:54:47 |
Message-ID: | 00b41d56-6706-27f0-1330-1ee685158017@oss.nttdata.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On 2020/06/18 14:40, Fujii Masao wrote:
>
>
> On 2020/06/18 11:44, Kyotaro Horiguchi wrote:
>> At Wed, 17 Jun 2020 20:13:01 +0900, Fujii Masao <masao(dot)fujii(at)oss(dot)nttdata(dot)com> wrote in
>>>> ReplicationSlotAcquireInternal. I think we should call
>>>> ConditionVariablePrepareToSleep before the sorrounding for statement
>>>> block.
>>>
>>> OK, so what about the attached patch? I added
>>> ConditionVariablePrepareToSleep()
>>> just before entering the "for" loop in
>>> InvalidateObsoleteReplicationSlots().
>>
>> Thanks.
>
> Thanks for the review!
>
>>
>> ReplicationSlotAcquireInternal:
>> + * If *slot == NULL, search for the slot with the given name.
>>
>> '*' seems needless here.
>
> Fixed.
>
> Also I added "Only one of slot and name can be specified." into
> the comments of ReplicationSlotAcquireInternal().
>
>
>> The patch moves ConditionVariablePrepareToSleep. We need to call the
>> function before looking into active_pid as originally commented.
>> Since it is not protected by ReplicationSlotControLock, just before
>> releasing the lock is not correct.
>>
>> The attached on top of the v3 fixes that.
>
> Yes, you're right. I merged your 0001.patch into mine.
>
> + if (behavior != SAB_Inquire)
> + ConditionVariablePrepareToSleep(&s->active_cv);
> + else if (behavior != SAB_Inquire)
>
> Isn't "behavior == SAB_Block" condition better here?
> I changed the patch that way.
>
> The attached is the updated version of the patch.
> I also merged Alvaro's patch into this.
>
>
>> + s = (slot == NULL) ? SearchNamedReplicationSlot(name) : slot;
>> + if (s == NULL || !s->in_use || strcmp(name, NameStr(s->data.name)) != 0)
>>
>> The conditions in the second line is needed for the case slot is
>> given, but it is already done in SearchNamedReplicationSlot if slot is
>> not given. I would like something like the following instead, but I
>> don't insist on it.
>
> Yes, I got rid of strcmp() check, but left is_use check as it is.
> I like that because it's simpler.
>
>
>> ReplicationSlot *s = NULL;
>> ...
>> if (!slot)
>> s = SearchNamedReplicationSlot(name);
>> else if(s->in_use && strcmp(name, NameStr(s->data.name)))
>> s = slot;
>>
>>
>> + ereport(ERROR,
>> + (errcode(ERRCODE_UNDEFINED_OBJECT),
>> + errmsg("replication slot \"%s\" does not exist", name)));
>>
>> The error message is not right when the given slot doesn't match the
>> given name.
>
> This doesn't happen after applying Alvaro's patch.
>
> BTW, using "name" here is not valid because it may be NULL.
> So I added the following code and used "slot_name" in log messages.
>
> + slot_name = name ? name : NameStr(slot->data.name);
Sorry, this caused compiler failure. So I fixed that and
attached the updated version of the patch.
Regards,
--
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION
Attachment | Content-Type | Size |
---|---|---|
invalidate_obsolete_replication_slots_v5.patch | text/plain | 9.6 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Thomas Munro | 2020-06-18 06:05:50 | Re: Fast DSM segments |
Previous Message | Fujii Masao | 2020-06-18 05:40:55 | Re: Review for GetWALAvailability() |