public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Paul Simmons <mbatranch@gmail.com>
To: development@lists.ipfire.org
Subject: Re: [PATCH 2/3] backup: Create tarball in one pass
Date: Mon, 06 Dec 2021 12:40:22 -0600	[thread overview]
Message-ID: <b8d8a326-4564-33db-da99-7b5230674a86@gmail.com> (raw)
In-Reply-To: <0d5f8563-2023-6a78-a197-dfcf9ed6095c@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 5423 bytes --]

On 12/3/21 07:54, Adolf Belka wrote:
> Hi Michael,
>
> On 02/12/2021 16:48, Michael Tremer wrote:
>> Hello Adolf,
>>
>> Thank you for reviewing my patch :)
>>
>>> On 2 Dec 2021, at 13:42, Adolf Belka <adolf.belka(a)ipfire.org> wrote:
>>>
>>> Hi Michael,
>>>
>>> I split the tar into two stages in May of this year as a fix for Bug
>>> #12626.
>>>
>>> If the tar/gzip is done in one go then any files in the include.user
>>> file that match a pattern in the global exclude will always be
>>> ignored as the --exclude-from has precedence over any file lists at
>>> the end of the command.
>>
>> I should have reached out because it wasn’t quite clear to me why
>> this was split into two operations.
>>
>> I would have considered this the expected behaviour, because what is
>> excluded is excluded. Clearly you expected something else to happen
>> which I would also consider a valid expectation.
> It wasn't me that highlighted that effect but Paul Simmons in Bug
> 11320 - Umbrella bug for backup system, comment 1. I took that and
> created Bug 12626. I have not had any problems myself with the user
> backup as it was previously running.
>>
>>> If this patch is implemented then I would edit the wiki to specify
>>> that user files, wanting to be backed up by adding to the
>>> include.user file, should not be in any of the directories listed in
>>> the global exclude file and must not have a .tmp extension.
>>
>> Is there any use-case where this would become a big problem? Is there
>> anything the user would include that has previously been globally
>> excluded?
> This question would need to be asked to Paul Simmons as he raised the
> bug in the first case. I don't know if he is included in the
> dewvlopment(a)lists.ipfire.org, if not then the simplest would be to add
> his name to this email series and see if we get a response.
> The issues that have been raised of the backup in the iso not working
> and the amount of disk space used with the temporary storage of the
> tar files instead of going direct to gzip would seem to be good
> reasons to revert the change I did anyway and then later, depending on
> the response from Paul Simmons, we can discuss further if a use case
> that needs to be addressed is identified.
>
> Does that seem a reasonable approach to this.
>
> Regards,
> Adolf.
>>
>> -Michael
>>
>>>
>>>
>>> Regards,
>>>
>>> Adolf.
>>>
>>>
>>> On 02/12/2021 13:37, Michael Tremer wrote:
>>>> This patch is changing the behaviour of the backup script so that it
>>>> creates one tarball and compresses it in one go.
>>>>
>>>> This will save storing the original tarball on disk before compressing
>>>> it which on my test system requires significant disk space.
>>>>
>>>> This patch also solves a bug where the backup file included with
>>>> the ISO
>>>> image could not be extracted because it was not gzip-compressed
>>>> when it
>>>> was expected to be.
>>>>
>>>> Signed-off-by: Michael Tremer <michael.tremer(a)ipfire.org>
>>>> ---
>>>>   config/backup/backup.pl | 15 ++++-----------
>>>>   1 file changed, 4 insertions(+), 11 deletions(-)
>>>>
>>>> diff --git a/config/backup/backup.pl b/config/backup/backup.pl
>>>> index 0b47af2d6..bed5952de 100644
>>>> --- a/config/backup/backup.pl
>>>> +++ b/config/backup/backup.pl
>>>> @@ -58,20 +58,13 @@ make_backup() {
>>>>       done
>>>>         # Backup using global exclude/include definitions
>>>> -    tar cvf "${filename}" \
>>>> +    tar cvfz "${filename}" \
>>>>           --exclude-from="/var/ipfire/backup/exclude" \
>>>> -        $(process_includes "/var/ipfire/backup/include") \
>>>> -        "$@"
>>>> -
>>>> -    # Backup using user exclude/include definitions and append to
>>>> global backup
>>>> -    tar rvf "${filename}" \
>>>>           --exclude-from="/var/ipfire/backup/exclude.user" \
>>>> +        $(process_includes "/var/ipfire/backup/include") \
>>>>           $(process_includes "/var/ipfire/backup/include.user") \
>>>>           "$@"
>>>>   -    # gzip the combined global/user backup and use .ipf suffix
>>>> -    gzip --suffix .ipf "${filename}"
>>>> -
>>>>       return 0
>>>>   }
>>>>   @@ -215,7 +208,7 @@ main() {
>>>>               local filename="${1}"
>>>>                 if [ -z "${filename}" ]; then
>>>> -                filename="/var/ipfire/backup/${NOW}"
>>>> +                filename="/var/ipfire/backup/${NOW}.ipf"
>>>>               fi
>>>>                 make_backup "${filename}" $(find_logfiles)
>>>> @@ -225,7 +218,7 @@ main() {
>>>>               local filename="${1}"
>>>>                 if [ -z "${filename}" ]; then
>>>> -                filename="/var/ipfire/backup/${NOW}"
>>>> +                filename="/var/ipfire/backup/${NOW}.ipf"
>>>>               fi
>>>>                 make_backup "${filename}"
>>>
>>> -- 
>>> Sent from my laptop
>>
>
Howdy, y'all.

I have an alternate solution for my use case.  I've created a pseudo
addon backup file which includes files that were omitted by the original
global include / exclude evaluations.

Thank you,

Paul Simmons


  reply	other threads:[~2021-12-06 18:40 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-12-02 12:37 [PATCH 1/3] backup: Use filename as specified on console Michael Tremer
2021-12-02 12:37 ` [PATCH 2/3] backup: Create tarball in one pass Michael Tremer
2021-12-02 13:42   ` Adolf Belka
2021-12-02 15:48     ` Michael Tremer
2021-12-03 13:54       ` Adolf Belka
2021-12-06 18:40         ` Paul Simmons [this message]
2021-12-02 12:37 ` [PATCH 3/3] backup: Fork ISO job into the background in CGI script Michael Tremer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=b8d8a326-4564-33db-da99-7b5230674a86@gmail.com \
    --to=mbatranch@gmail.com \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox