Обсуждение: max_slot_wal_keep_size and wal_keep_segments

Поиск
Список
Период
Сортировка

max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:
Hi,

When I talked about max_slot_wal_keep_size as new feature in v13
at the conference, I received the question like "Why are the units of
setting values in max_slot_wal_keep_size and wal_keep_segments different?"
from audience. That difference looks confusing for users and
IMO it's better to use the same unit for them. Thought?

There seem to be several options to do this.

(1) Rename max_slot_wal_keep_size to max_slot_wal_keep_segments,
     and make users specify the number of WAL segments in it instead of
     WAL size.

(2) Rename wal_keep_segments to wal_keep_size, and make users specify
      the WAL size in it instead of the number of WAL segments.

(3) Don't rename the parameters, and allow users to specify not only
     the number of WAL segments but also the WAL size in wal_keep_segments.

Since we have been moving away from measuring in segments, e.g.,
max_wal_size, I don't think (1) is good idea.

For backward compatibility, (3) is better. But which needs more
(maybe a bit complicated) code in guc.c. Also the parameter names
are not consistent yet (i.e., _segments and _size).

So for now I like (2).

Thought?

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



Re: max_slot_wal_keep_size and wal_keep_segments

От
Kyotaro Horiguchi
Дата:
At Tue, 30 Jun 2020 23:51:40 +0900, Fujii Masao <masao.fujii@oss.nttdata.com> wrote in 
> Hi,
> 
> When I talked about max_slot_wal_keep_size as new feature in v13
> at the conference, I received the question like "Why are the units of
> setting values in max_slot_wal_keep_size and wal_keep_segments
> different?"
> from audience. That difference looks confusing for users and
> IMO it's better to use the same unit for them. Thought?

We are moving the units for amount of WAL from segments to MB.  The
variable is affected by the movement.  I'm not sure wal_keep_segments
is going to die soon but we may change it to wal_keep_size(_mb) sooner
or later if it going to stay alive.

> There seem to be several options to do this.
> 
> (1) Rename max_slot_wal_keep_size to max_slot_wal_keep_segments,
>     and make users specify the number of WAL segments in it instead of
>     WAL size.

I don't think this is not the way.

> (2) Rename wal_keep_segments to wal_keep_size, and make users specify
>      the WAL size in it instead of the number of WAL segments.

Yes. I agree to this (as I wrote above before reading this).

> (3) Don't rename the parameters, and allow users to specify not only
>     the number of WAL segments but also the WAL size in wal_keep_segments.

Possible in a short term, but not for a long term.

> Since we have been moving away from measuring in segments, e.g.,
> max_wal_size, I don't think (1) is good idea.
> 
> For backward compatibility, (3) is better. But which needs more
> (maybe a bit complicated) code in guc.c. Also the parameter names
> are not consistent yet (i.e., _segments and _size).
> 
> So for now I like (2).
> 
> Thought?

I agree to you.  If someone found that wal_keep_segment is no longer
usable, the alternative would easily be found by searching config file
for "wal_keep". Or we could have a default config line like this:

wal_keep_size = 0     # in megabytes: 0 disables (formerly wal_keep_segments)

regards.

-- 
Kyotaro Horiguchi
NTT Open Source Software Center



Re: max_slot_wal_keep_size and wal_keep_segments

От
Alvaro Herrera
Дата:
On 2020-Jun-30, Fujii Masao wrote:

> Hi,
> 
> When I talked about max_slot_wal_keep_size as new feature in v13
> at the conference, I received the question like "Why are the units of
> setting values in max_slot_wal_keep_size and wal_keep_segments different?"
> from audience. That difference looks confusing for users and
> IMO it's better to use the same unit for them. Thought?

Do we still need wal_keep_segments for anything?  Maybe we should
consider removing that functionality instead ... and even if we don't
remove it in 13, then what is the point of renaming it only to remove it
shortly after?

-- 
Álvaro Herrera                https://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/01 12:26, Alvaro Herrera wrote:
> On 2020-Jun-30, Fujii Masao wrote:
> 
>> Hi,
>>
>> When I talked about max_slot_wal_keep_size as new feature in v13
>> at the conference, I received the question like "Why are the units of
>> setting values in max_slot_wal_keep_size and wal_keep_segments different?"
>> from audience. That difference looks confusing for users and
>> IMO it's better to use the same unit for them. Thought?
> 
> Do we still need wal_keep_segments for anything?

Yeah, personally I like wal_keep_segments because its setting is very
simple and no extra operations on replication slots are necessary.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



Re: max_slot_wal_keep_size and wal_keep_segments

От
Alvaro Herrera
Дата:
On 2020-Jul-01, Fujii Masao wrote:

> On 2020/07/01 12:26, Alvaro Herrera wrote:
> > On 2020-Jun-30, Fujii Masao wrote:
> > 
> > > When I talked about max_slot_wal_keep_size as new feature in v13
> > > at the conference, I received the question like "Why are the units of
> > > setting values in max_slot_wal_keep_size and wal_keep_segments different?"
> > > from audience. That difference looks confusing for users and
> > > IMO it's better to use the same unit for them. Thought?
> > 
> > Do we still need wal_keep_segments for anything?
> 
> Yeah, personally I like wal_keep_segments because its setting is very
> simple and no extra operations on replication slots are necessary.

Okay.  In that case I +1 the idea of renaming to wal_keep_size.

-- 
Álvaro Herrera                https://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services



Re: max_slot_wal_keep_size and wal_keep_segments

От
David Steele
Дата:
On 7/1/20 10:54 AM, Alvaro Herrera wrote:
> On 2020-Jul-01, Fujii Masao wrote:
> 
>> On 2020/07/01 12:26, Alvaro Herrera wrote:
>>> On 2020-Jun-30, Fujii Masao wrote:
>>>
>>>> When I talked about max_slot_wal_keep_size as new feature in v13
>>>> at the conference, I received the question like "Why are the units of
>>>> setting values in max_slot_wal_keep_size and wal_keep_segments different?"
>>>> from audience. That difference looks confusing for users and
>>>> IMO it's better to use the same unit for them. Thought?
>>>
>>> Do we still need wal_keep_segments for anything?
>>
>> Yeah, personally I like wal_keep_segments because its setting is very
>> simple and no extra operations on replication slots are necessary.
> 
> Okay.  In that case I +1 the idea of renaming to wal_keep_size.

+1 for renaming to wal_keep_size.

-- 
-David
david@pgmasters.net



Re: max_slot_wal_keep_size and wal_keep_segments

От
Masahiko Sawada
Дата:
On Thu, 2 Jul 2020 at 02:18, David Steele <david@pgmasters.net> wrote:
>
> On 7/1/20 10:54 AM, Alvaro Herrera wrote:
> > On 2020-Jul-01, Fujii Masao wrote:
> >
> >> On 2020/07/01 12:26, Alvaro Herrera wrote:
> >>> On 2020-Jun-30, Fujii Masao wrote:
> >>>
> >>>> When I talked about max_slot_wal_keep_size as new feature in v13
> >>>> at the conference, I received the question like "Why are the units of
> >>>> setting values in max_slot_wal_keep_size and wal_keep_segments different?"
> >>>> from audience. That difference looks confusing for users and
> >>>> IMO it's better to use the same unit for them. Thought?
> >>>
> >>> Do we still need wal_keep_segments for anything?
> >>
> >> Yeah, personally I like wal_keep_segments because its setting is very
> >> simple and no extra operations on replication slots are necessary.
> >
> > Okay.  In that case I +1 the idea of renaming to wal_keep_size.
>
> +1 for renaming to wal_keep_size.
>

+1 from me, too.

Regards,


--
Masahiko Sawada            http://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/02 2:18, David Steele wrote:
> On 7/1/20 10:54 AM, Alvaro Herrera wrote:
>> On 2020-Jul-01, Fujii Masao wrote:
>>
>>> On 2020/07/01 12:26, Alvaro Herrera wrote:
>>>> On 2020-Jun-30, Fujii Masao wrote:
>>>>
>>>>> When I talked about max_slot_wal_keep_size as new feature in v13
>>>>> at the conference, I received the question like "Why are the units of
>>>>> setting values in max_slot_wal_keep_size and wal_keep_segments different?"
>>>>> from audience. That difference looks confusing for users and
>>>>> IMO it's better to use the same unit for them. Thought?
>>>>
>>>> Do we still need wal_keep_segments for anything?
>>>
>>> Yeah, personally I like wal_keep_segments because its setting is very
>>> simple and no extra operations on replication slots are necessary.
>>
>> Okay.  In that case I +1 the idea of renaming to wal_keep_size.
> 
> +1 for renaming to wal_keep_size.

I attached the patch that renames wal_keep_segments to wal_keep_size.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION

Вложения

Re: max_slot_wal_keep_size and wal_keep_segments

От
Alvaro Herrera
Дата:
On 2020-Jul-09, Fujii Masao wrote:

> I attached the patch that renames wal_keep_segments to wal_keep_size.

Looks good in a quick once-over.  Just two small wording comments:

>    <para>
>     Independently of <varname>max_wal_size</varname>,
> -   <xref linkend="guc-wal-keep-segments"/> + 1 most recent WAL files are
> +   most recent <xref linkend="guc-wal-keep-size"/> megabytes
> +   WAL files plus one WAL file are
>     kept at all times. Also, if WAL archiving is used, old segments can not be
>     removed or recycled until they are archived. If WAL archiving cannot keep up
>     with the pace that WAL is generated, or if <varname>archive_command</varname>

This reads a little strange to me.  Maybe "the N most recent megabytes
plus ..."

>              /* determine how many segments slots can be kept by slots ... */
> -            keepSegs = XLogMBVarToSegs(max_slot_wal_keep_size_mb, wal_segment_size);
> -            /* ... and override by wal_keep_segments as needed */
> -            keepSegs = Max(keepSegs, wal_keep_segments);
> +            slotKeepSegs = XLogMBVarToSegs(max_slot_wal_keep_size_mb, wal_segment_size);
> +            /* ... and override by wal_keep_size as needed */
> +            keepSegs = XLogMBVarToSegs(wal_keep_size_mb, wal_segment_size);

Since you change the way these two variables are used, I would not say
"override" in the above comment, nor keep the ellipses; perhaps just
change them to "determine how many segments can be kept by slots" and
"ditto for wal_keep_size".

-- 
Álvaro Herrera                https://www.2ndQuadrant.com/
PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services



Re: max_slot_wal_keep_size and wal_keep_segments

От
Kyotaro Horiguchi
Дата:
At Thu, 9 Jul 2020 00:37:57 +0900, Fujii Masao <masao.fujii@oss.nttdata.com> wrote in
>
>
> On 2020/07/02 2:18, David Steele wrote:
> > On 7/1/20 10:54 AM, Alvaro Herrera wrote:
> >> On 2020-Jul-01, Fujii Masao wrote:
> >>
> >>> On 2020/07/01 12:26, Alvaro Herrera wrote:
> >>>> On 2020-Jun-30, Fujii Masao wrote:
> >>>>
> >>>>> When I talked about max_slot_wal_keep_size as new feature in v13
> >>>>> at the conference, I received the question like "Why are the units of
> >>>>> setting values in max_slot_wal_keep_size and wal_keep_segments
> >>>>> different?"
> >>>>> from audience. That difference looks confusing for users and
> >>>>> IMO it's better to use the same unit for them. Thought?
> >>>>
> >>>> Do we still need wal_keep_segments for anything?
> >>>
> >>> Yeah, personally I like wal_keep_segments because its setting is very
> >>> simple and no extra operations on replication slots are necessary.
> >>
> >> Okay.  In that case I +1 the idea of renaming to wal_keep_size.
> > +1 for renaming to wal_keep_size.
>
> I attached the patch that renames wal_keep_segments to wal_keep_size.

It fails on 019_replslot_limit.pl for uncertain reason to me..


@@ -11323,7 +11329,7 @@ do_pg_stop_backup(char *labelfile, bool waitforarchive, TimeLineID *stoptli_p)
      * If archiving is enabled, wait for all the required WAL files to be
      * archived before returning. If archiving isn't enabled, the required WAL
      * needs to be transported via streaming replication (hopefully with
-     * wal_keep_segments set high enough), or some more exotic mechanism like
+     * wal_keep_size set high enough), or some more exotic mechanism like
      * polling and copying files from pg_wal with script. We have no knowledge

Isn't this time a good chance to mention replication slots?


-    "ALTER SYSTEM SET wal_keep_segments to 8; SELECT pg_reload_conf();");
+    "ALTER SYSTEM SET wal_keep_size to '128MB'; SELECT pg_reload_conf();");

wal_segment_size to 1MB here so, that conversion is not correct.
(However, that test works as long as it is more than
max_slot_wal_keep_size so it's practically no problem.)

regards.

--
Kyotaro Horiguchi
NTT Open Source Software Center



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/09 1:20, Alvaro Herrera wrote:
> On 2020-Jul-09, Fujii Masao wrote:
> 
>> I attached the patch that renames wal_keep_segments to wal_keep_size.
> 
> Looks good in a quick once-over.  Just two small wording comments:

Thanks for review comments!


> 
>>     <para>
>>      Independently of <varname>max_wal_size</varname>,
>> -   <xref linkend="guc-wal-keep-segments"/> + 1 most recent WAL files are
>> +   most recent <xref linkend="guc-wal-keep-size"/> megabytes
>> +   WAL files plus one WAL file are
>>      kept at all times. Also, if WAL archiving is used, old segments can not be
>>      removed or recycled until they are archived. If WAL archiving cannot keep up
>>      with the pace that WAL is generated, or if <varname>archive_command</varname>
> 
> This reads a little strange to me.  Maybe "the N most recent megabytes
> plus ..."

Yes, fixed.


> 
>>               /* determine how many segments slots can be kept by slots ... */
>> -            keepSegs = XLogMBVarToSegs(max_slot_wal_keep_size_mb, wal_segment_size);
>> -            /* ... and override by wal_keep_segments as needed */
>> -            keepSegs = Max(keepSegs, wal_keep_segments);
>> +            slotKeepSegs = XLogMBVarToSegs(max_slot_wal_keep_size_mb, wal_segment_size);
>> +            /* ... and override by wal_keep_size as needed */
>> +            keepSegs = XLogMBVarToSegs(wal_keep_size_mb, wal_segment_size);
> 
> Since you change the way these two variables are used, I would not say
> "override" in the above comment, nor keep the ellipses; perhaps just
> change them to "determine how many segments can be kept by slots" and
> "ditto for wal_keep_size".

Yes, fixed.

Attached is the updated version of the patch.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION

Вложения

Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/09 13:47, Kyotaro Horiguchi wrote:
> At Thu, 9 Jul 2020 00:37:57 +0900, Fujii Masao <masao.fujii@oss.nttdata.com> wrote in
>>
>>
>> On 2020/07/02 2:18, David Steele wrote:
>>> On 7/1/20 10:54 AM, Alvaro Herrera wrote:
>>>> On 2020-Jul-01, Fujii Masao wrote:
>>>>
>>>>> On 2020/07/01 12:26, Alvaro Herrera wrote:
>>>>>> On 2020-Jun-30, Fujii Masao wrote:
>>>>>>
>>>>>>> When I talked about max_slot_wal_keep_size as new feature in v13
>>>>>>> at the conference, I received the question like "Why are the units of
>>>>>>> setting values in max_slot_wal_keep_size and wal_keep_segments
>>>>>>> different?"
>>>>>>> from audience. That difference looks confusing for users and
>>>>>>> IMO it's better to use the same unit for them. Thought?
>>>>>>
>>>>>> Do we still need wal_keep_segments for anything?
>>>>>
>>>>> Yeah, personally I like wal_keep_segments because its setting is very
>>>>> simple and no extra operations on replication slots are necessary.
>>>>
>>>> Okay.  In that case I +1 the idea of renaming to wal_keep_size.
>>> +1 for renaming to wal_keep_size.
>>
>> I attached the patch that renames wal_keep_segments to wal_keep_size.
> 
> It fails on 019_replslot_limit.pl for uncertain reason to me..

I could not reproduce this...


> 
> 
> @@ -11323,7 +11329,7 @@ do_pg_stop_backup(char *labelfile, bool waitforarchive, TimeLineID *stoptli_p)
>        * If archiving is enabled, wait for all the required WAL files to be
>        * archived before returning. If archiving isn't enabled, the required WAL
>        * needs to be transported via streaming replication (hopefully with
> -     * wal_keep_segments set high enough), or some more exotic mechanism like
> +     * wal_keep_size set high enough), or some more exotic mechanism like
>        * polling and copying files from pg_wal with script. We have no knowledge
> 
> Isn't this time a good chance to mention replication slots?

+1 to do that. But I found there are other places where replication slots
need to be mentioned. So I think it's better to do this as separate patch.


> 
> 
> -    "ALTER SYSTEM SET wal_keep_segments to 8; SELECT pg_reload_conf();");
> +    "ALTER SYSTEM SET wal_keep_size to '128MB'; SELECT pg_reload_conf();");
> 
> wal_segment_size to 1MB here so, that conversion is not correct.
> (However, that test works as long as it is more than
> max_slot_wal_keep_size so it's practically no problem.)

So I changed 128MB to 8MB. Is this OK?
I attached the updated version of the patch upthread.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



Re: max_slot_wal_keep_size and wal_keep_segments

От
Kyotaro Horiguchi
Дата:
At Mon, 13 Jul 2020 14:14:30 +0900, Fujii Masao <masao.fujii@oss.nttdata.com> wrote in
>
>
> On 2020/07/09 13:47, Kyotaro Horiguchi wrote:
> > At Thu, 9 Jul 2020 00:37:57 +0900, Fujii Masao
> > <masao.fujii@oss.nttdata.com> wrote in
> >>
> >>
> >> On 2020/07/02 2:18, David Steele wrote:
> >>> On 7/1/20 10:54 AM, Alvaro Herrera wrote:
> >>>> On 2020-Jul-01, Fujii Masao wrote:
> >>>>
> >>>>> On 2020/07/01 12:26, Alvaro Herrera wrote:
> >>>>>> On 2020-Jun-30, Fujii Masao wrote:
> >>>>>>
> >>>>>>> When I talked about max_slot_wal_keep_size as new feature in v13
> >>>>>>> at the conference, I received the question like "Why are the units of
> >>>>>>> setting values in max_slot_wal_keep_size and wal_keep_segments
> >>>>>>> different?"
> >>>>>>> from audience. That difference looks confusing for users and
> >>>>>>> IMO it's better to use the same unit for them. Thought?
> >>>>>>
> >>>>>> Do we still need wal_keep_segments for anything?
> >>>>>
> >>>>> Yeah, personally I like wal_keep_segments because its setting is very
> >>>>> simple and no extra operations on replication slots are necessary.
> >>>>
> >>>> Okay.  In that case I +1 the idea of renaming to wal_keep_size.
> >>> +1 for renaming to wal_keep_size.
> >>
> >> I attached the patch that renames wal_keep_segments to wal_keep_size.
> > It fails on 019_replslot_limit.pl for uncertain reason to me..
>
> I could not reproduce this...

Sorry for the ambiguity.  The patch didn't applied on the file, and I
noticed that the reason is the wording change from master to
primary. So no problem in the latest patch.

> > @@ -11323,7 +11329,7 @@ do_pg_stop_backup(char *labelfile, bool
> > waitforarchive, TimeLineID *stoptli_p)
> >        * If archiving is enabled, wait for all the required WAL files to be
> >        * archived before returning. If archiving isn't enabled, the required
> >        * WAL
> >        * needs to be transported via streaming replication (hopefully with
> > -     * wal_keep_segments set high enough), or some more exotic mechanism like
> > + * wal_keep_size set high enough), or some more exotic mechanism like
> >        * polling and copying files from pg_wal with script. We have no
> >        * knowledge
> > Isn't this time a good chance to mention replication slots?
>
> +1 to do that. But I found there are other places where replication
> slots
> need to be mentioned. So I think it's better to do this as separate
> patch.

Agreed.

> > -    "ALTER SYSTEM SET wal_keep_segments to 8; SELECT pg_reload_conf();");
> > + "ALTER SYSTEM SET wal_keep_size to '128MB'; SELECT
> > pg_reload_conf();");
> > wal_segment_size to 1MB here so, that conversion is not correct.
> > (However, that test works as long as it is more than
> > max_slot_wal_keep_size so it's practically no problem.)
>
> So I changed 128MB to 8MB. Is this OK?
> I attached the updated version of the patch upthread.

That change looks find by me.

regards.

--
Kyotaro Horiguchi
NTT Open Source Software Center



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/13 16:01, Kyotaro Horiguchi wrote:
> At Mon, 13 Jul 2020 14:14:30 +0900, Fujii Masao <masao.fujii@oss.nttdata.com> wrote in
>>
>>
>> On 2020/07/09 13:47, Kyotaro Horiguchi wrote:
>>> At Thu, 9 Jul 2020 00:37:57 +0900, Fujii Masao
>>> <masao.fujii@oss.nttdata.com> wrote in
>>>>
>>>>
>>>> On 2020/07/02 2:18, David Steele wrote:
>>>>> On 7/1/20 10:54 AM, Alvaro Herrera wrote:
>>>>>> On 2020-Jul-01, Fujii Masao wrote:
>>>>>>
>>>>>>> On 2020/07/01 12:26, Alvaro Herrera wrote:
>>>>>>>> On 2020-Jun-30, Fujii Masao wrote:
>>>>>>>>
>>>>>>>>> When I talked about max_slot_wal_keep_size as new feature in v13
>>>>>>>>> at the conference, I received the question like "Why are the units of
>>>>>>>>> setting values in max_slot_wal_keep_size and wal_keep_segments
>>>>>>>>> different?"
>>>>>>>>> from audience. That difference looks confusing for users and
>>>>>>>>> IMO it's better to use the same unit for them. Thought?
>>>>>>>>
>>>>>>>> Do we still need wal_keep_segments for anything?
>>>>>>>
>>>>>>> Yeah, personally I like wal_keep_segments because its setting is very
>>>>>>> simple and no extra operations on replication slots are necessary.
>>>>>>
>>>>>> Okay.  In that case I +1 the idea of renaming to wal_keep_size.
>>>>> +1 for renaming to wal_keep_size.
>>>>
>>>> I attached the patch that renames wal_keep_segments to wal_keep_size.
>>> It fails on 019_replslot_limit.pl for uncertain reason to me..
>>
>> I could not reproduce this...
> 
> Sorry for the ambiguity.  The patch didn't applied on the file, and I
> noticed that the reason is the wording change from master to
> primary. So no problem in the latest patch.
> 
>>> @@ -11323,7 +11329,7 @@ do_pg_stop_backup(char *labelfile, bool
>>> waitforarchive, TimeLineID *stoptli_p)
>>>         * If archiving is enabled, wait for all the required WAL files to be
>>>         * archived before returning. If archiving isn't enabled, the required
>>>         * WAL
>>>         * needs to be transported via streaming replication (hopefully with
>>> -     * wal_keep_segments set high enough), or some more exotic mechanism like
>>> + * wal_keep_size set high enough), or some more exotic mechanism like
>>>         * polling and copying files from pg_wal with script. We have no
>>>         * knowledge
>>> Isn't this time a good chance to mention replication slots?
>>
>> +1 to do that. But I found there are other places where replication
>> slots
>> need to be mentioned. So I think it's better to do this as separate
>> patch.
> 
> Agreed.
> 
>>> -    "ALTER SYSTEM SET wal_keep_segments to 8; SELECT pg_reload_conf();");
>>> + "ALTER SYSTEM SET wal_keep_size to '128MB'; SELECT
>>> pg_reload_conf();");
>>> wal_segment_size to 1MB here so, that conversion is not correct.
>>> (However, that test works as long as it is more than
>>> max_slot_wal_keep_size so it's practically no problem.)
>>
>> So I changed 128MB to 8MB. Is this OK?
>> I attached the updated version of the patch upthread.
> 
> That change looks find by me.

Thanks for the review!

The patch was no longer applied cleanly because of recent commit.
So I updated the patch. Attached.

Barring any objection, I will commit this patch.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION

Вложения

Re: max_slot_wal_keep_size and wal_keep_segments

От
David Steele
Дата:
On 7/14/20 12:00 AM, Fujii Masao wrote:
> 
> The patch was no longer applied cleanly because of recent commit.
> So I updated the patch. Attached.
> 
> Barring any objection, I will commit this patch.

This doesn't look right:

+   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
+   WAL files plus one WAL file are

How about:

+   <xref linkend="guc-wal-keep-size"/> megabytes of
+   WAL files plus one WAL file are

Other than that, looks good to me.

Regards,
-- 
-David
david@pgmasters.net



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/14 20:30, David Steele wrote:
> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>
>> The patch was no longer applied cleanly because of recent commit.
>> So I updated the patch. Attached.
>>
>> Barring any objection, I will commit this patch.
> 
> This doesn't look right:
> 
> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
> +   WAL files plus one WAL file are
> 
> How about:
> 
> +   <xref linkend="guc-wal-keep-size"/> megabytes of
> +   WAL files plus one WAL file are

Thanks for the comment! Isn't it better to keep "most recent" part?
If so, what about either of the followings?

1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
     one WAL file that were most recently generated are kept all time.

2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref linkend="guc-wal-segment-size"> bytes
     of WAL files that were most recently generated are kept all time.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



Re: max_slot_wal_keep_size and wal_keep_segments

От
David Steele
Дата:
On 7/17/20 5:11 AM, Fujii Masao wrote:
> 
> 
> On 2020/07/14 20:30, David Steele wrote:
>> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>>
>>> The patch was no longer applied cleanly because of recent commit.
>>> So I updated the patch. Attached.
>>>
>>> Barring any objection, I will commit this patch.
>>
>> This doesn't look right:
>>
>> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
>> +   WAL files plus one WAL file are
>>
>> How about:
>>
>> +   <xref linkend="guc-wal-keep-size"/> megabytes of
>> +   WAL files plus one WAL file are
> 
> Thanks for the comment! Isn't it better to keep "most recent" part?
> If so, what about either of the followings?
> 
> 1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
>      one WAL file that were most recently generated are kept all time.
> 
> 2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref 
> linkend="guc-wal-segment-size"> bytes
>      of WAL files that were most recently generated are kept all time.

"most recent" seemed implied to me, but I see your point.

How about:

+   the most recent <xref linkend="guc-wal-keep-size"/> megabytes of
+   WAL files plus one additional WAL file are

Regards,
-- 
-David
david@pgmasters.net



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/17 20:24, David Steele wrote:
> 
> On 7/17/20 5:11 AM, Fujii Masao wrote:
>>
>>
>> On 2020/07/14 20:30, David Steele wrote:
>>> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>>>
>>>> The patch was no longer applied cleanly because of recent commit.
>>>> So I updated the patch. Attached.
>>>>
>>>> Barring any objection, I will commit this patch.
>>>
>>> This doesn't look right:
>>>
>>> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
>>> +   WAL files plus one WAL file are
>>>
>>> How about:
>>>
>>> +   <xref linkend="guc-wal-keep-size"/> megabytes of
>>> +   WAL files plus one WAL file are
>>
>> Thanks for the comment! Isn't it better to keep "most recent" part?
>> If so, what about either of the followings?
>>
>> 1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
>>      one WAL file that were most recently generated are kept all time.
>>
>> 2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref linkend="guc-wal-segment-size"> bytes
>>      of WAL files that were most recently generated are kept all time.
> 
> "most recent" seemed implied to me, but I see your point.
> 
> How about:
> 
> +   the most recent <xref linkend="guc-wal-keep-size"/> megabytes of
> +   WAL files plus one additional WAL file are

I adopted this and pushed the patch. Thanks!

Also we need to update the release note for v13. What about adding the following?

------------------------------------
Rename configuration parameter wal_keep_segments to wal_keep_size.

This allows how much WAL files to retain for the standby server, by bytes instead of the number of files.
If you previously used wal_keep_segments, the following formula will give you an approximately equivalent setting:

wal_keep_size = wal_keep_segments * wal_segment_size (typically 16MB)
------------------------------------


Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/20 13:48, Fujii Masao wrote:
> 
> 
> On 2020/07/17 20:24, David Steele wrote:
>>
>> On 7/17/20 5:11 AM, Fujii Masao wrote:
>>>
>>>
>>> On 2020/07/14 20:30, David Steele wrote:
>>>> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>>>>
>>>>> The patch was no longer applied cleanly because of recent commit.
>>>>> So I updated the patch. Attached.
>>>>>
>>>>> Barring any objection, I will commit this patch.
>>>>
>>>> This doesn't look right:
>>>>
>>>> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
>>>> +   WAL files plus one WAL file are
>>>>
>>>> How about:
>>>>
>>>> +   <xref linkend="guc-wal-keep-size"/> megabytes of
>>>> +   WAL files plus one WAL file are
>>>
>>> Thanks for the comment! Isn't it better to keep "most recent" part?
>>> If so, what about either of the followings?
>>>
>>> 1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
>>>      one WAL file that were most recently generated are kept all time.
>>>
>>> 2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref linkend="guc-wal-segment-size"> bytes
>>>      of WAL files that were most recently generated are kept all time.
>>
>> "most recent" seemed implied to me, but I see your point.
>>
>> How about:
>>
>> +   the most recent <xref linkend="guc-wal-keep-size"/> megabytes of
>> +   WAL files plus one additional WAL file are
> 
> I adopted this and pushed the patch. Thanks!
> 
> Also we need to update the release note for v13. What about adding the following?
> 
> ------------------------------------
> Rename configuration parameter wal_keep_segments to wal_keep_size.
> 
> This allows how much WAL files to retain for the standby server, by bytes instead of the number of files.
> If you previously used wal_keep_segments, the following formula will give you an approximately equivalent setting:
> 
> wal_keep_size = wal_keep_segments * wal_segment_size (typically 16MB)
> ------------------------------------

Patch attached.

Regards,

-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION

Вложения

Re: max_slot_wal_keep_size and wal_keep_segments

От
David Steele
Дата:
On 7/20/20 6:02 AM, Fujii Masao wrote:
> 
> 
> On 2020/07/20 13:48, Fujii Masao wrote:
>>
>>
>> On 2020/07/17 20:24, David Steele wrote:
>>>
>>> On 7/17/20 5:11 AM, Fujii Masao wrote:
>>>>
>>>>
>>>> On 2020/07/14 20:30, David Steele wrote:
>>>>> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>>>>>
>>>>>> The patch was no longer applied cleanly because of recent commit.
>>>>>> So I updated the patch. Attached.
>>>>>>
>>>>>> Barring any objection, I will commit this patch.
>>>>>
>>>>> This doesn't look right:
>>>>>
>>>>> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
>>>>> +   WAL files plus one WAL file are
>>>>>
>>>>> How about:
>>>>>
>>>>> +   <xref linkend="guc-wal-keep-size"/> megabytes of
>>>>> +   WAL files plus one WAL file are
>>>>
>>>> Thanks for the comment! Isn't it better to keep "most recent" part?
>>>> If so, what about either of the followings?
>>>>
>>>> 1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
>>>>      one WAL file that were most recently generated are kept all time.
>>>>
>>>> 2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref 
>>>> linkend="guc-wal-segment-size"> bytes
>>>>      of WAL files that were most recently generated are kept all time.
>>>
>>> "most recent" seemed implied to me, but I see your point.
>>>
>>> How about:
>>>
>>> +   the most recent <xref linkend="guc-wal-keep-size"/> megabytes of
>>> +   WAL files plus one additional WAL file are
>>
>> I adopted this and pushed the patch. Thanks!
>>
>> Also we need to update the release note for v13. What about adding the 
>> following?
>>
>> ------------------------------------
>> Rename configuration parameter wal_keep_segments to wal_keep_size.
>>
>> This allows how much WAL files to retain for the standby server, by 
>> bytes instead of the number of files.
>> If you previously used wal_keep_segments, the following formula will 
>> give you an approximately equivalent setting:
>>
>> wal_keep_size = wal_keep_segments * wal_segment_size (typically 16MB)
>> ------------------------------------

I would rework that first sentence a bit. How about:

+ This determines how much WAL to retain for the standby server,
+ specified in megabytes rather than number of files.

The rest looks fine to me.

Regards,
-- 
-David
david@pgmasters.net



Re: max_slot_wal_keep_size and wal_keep_segments

От
Fujii Masao
Дата:

On 2020/07/20 21:21, David Steele wrote:
> On 7/20/20 6:02 AM, Fujii Masao wrote:
>>
>>
>> On 2020/07/20 13:48, Fujii Masao wrote:
>>>
>>>
>>> On 2020/07/17 20:24, David Steele wrote:
>>>>
>>>> On 7/17/20 5:11 AM, Fujii Masao wrote:
>>>>>
>>>>>
>>>>> On 2020/07/14 20:30, David Steele wrote:
>>>>>> On 7/14/20 12:00 AM, Fujii Masao wrote:
>>>>>>>
>>>>>>> The patch was no longer applied cleanly because of recent commit.
>>>>>>> So I updated the patch. Attached.
>>>>>>>
>>>>>>> Barring any objection, I will commit this patch.
>>>>>>
>>>>>> This doesn't look right:
>>>>>>
>>>>>> +   the <xref linkend="guc-wal-keep-size"/> most recent megabytes
>>>>>> +   WAL files plus one WAL file are
>>>>>>
>>>>>> How about:
>>>>>>
>>>>>> +   <xref linkend="guc-wal-keep-size"/> megabytes of
>>>>>> +   WAL files plus one WAL file are
>>>>>
>>>>> Thanks for the comment! Isn't it better to keep "most recent" part?
>>>>> If so, what about either of the followings?
>>>>>
>>>>> 1. <xref linkend="guc-wal-keep-size"/> megabytes of WAL files plus
>>>>>      one WAL file that were most recently generated are kept all time.
>>>>>
>>>>> 2. <xref linkend="guc-wal-keep-size"/> megabytes + <xref linkend="guc-wal-segment-size"> bytes
>>>>>      of WAL files that were most recently generated are kept all time.
>>>>
>>>> "most recent" seemed implied to me, but I see your point.
>>>>
>>>> How about:
>>>>
>>>> +   the most recent <xref linkend="guc-wal-keep-size"/> megabytes of
>>>> +   WAL files plus one additional WAL file are
>>>
>>> I adopted this and pushed the patch. Thanks!
>>>
>>> Also we need to update the release note for v13. What about adding the following?
>>>
>>> ------------------------------------
>>> Rename configuration parameter wal_keep_segments to wal_keep_size.
>>>
>>> This allows how much WAL files to retain for the standby server, by bytes instead of the number of files.
>>> If you previously used wal_keep_segments, the following formula will give you an approximately equivalent setting:
>>>
>>> wal_keep_size = wal_keep_segments * wal_segment_size (typically 16MB)
>>> ------------------------------------
> 
> I would rework that first sentence a bit. How about:
> 
> + This determines how much WAL to retain for the standby server,
> + specified in megabytes rather than number of files.
> 
> The rest looks fine to me.

Thanks for the review!
I adopted your suggestion in the updated version of the patch and pushed it.

Regards,


-- 
Fujii Masao
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION