-
Notifications
You must be signed in to change notification settings - Fork 216
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make EXTREMELY CLEAR that the Auto-remove options take priority over all the "Keep one snapshot for/per" options / Rename "Smart remove" #1679
Comments
Or even better, let the user choose whether any of the "one per" is sacred and survives even running out of space. |
Ugh, and while it was creating today's backup with that folder excluded, it eliminated yesterday's, I guess because it checked whether should erase whole snapshots before noticing the option of just erasing the excluded folder from all snapshots... *sighs* edit: Hm, wait, where is that option? I could swear it was there before.... Maybe it was a manually added option in the Expert tab got lost on on upgrade or let it slip when migrating to a new hardware years ago and never noticed? O r am I just not looking in the right place? Or is it expected to do that by default and it wouldn't show as an option? edit2: Ok, I'm not insane, |
Dear Tiago, Please try to explain the problem in more details and steps. I did not understand your problem description. Also please describe the situation and steps that triggered that problem. And please provide some more basic information. Run Best, |
It's two problems:
I don't remember where I got it from, had it setup starting many years ago. And at the moment I'm running Linux Mint 20.3, Kernel 5.15.0-101-generic. |
Thanks a lot for the details. One further question. You wrote: "I accidentally added a very big folder as a subfolder to one of the folder being backed up and it blew up the free-space limit". This is about the bind-mount you mentioned in your initial post, right? Do you mean that you added this folder to your backup source or to your backup destination? |
On the source side. From what I understand, most software will just see that as the same thing as the folder and it's contents actually being there. On a somewhat unrelated note, I found the bind trick when looking for a work-around for git not handling symlinks well, and I need one single file inside that folder to be watched by git, but the rest of the folder has way too much data so it's added to |
Hello TiagoTiago, Problem A: Free space rule over Smart remove rules
Am I right so far? Problem B: Excluded folders not deleted in previous snapshotsThe second problem is about
|
Your summary of Problem A seems to cover it well. As for Problem B:
So Problem B involved a manifestation of Problem A triggered by not removing the now excluded big folder from the previous snapshot and just nuking the whole thing. And now that I'm thinking about it; maybe I might not even have reached the point of Problem A getting triggered the first time if the |
About BStill not sure if I understand everything needed about Problem B. My argument would be that old snapshots never modified (except they are completely removed). It does not matter for previous and still existing snapshots what is in the include and exclude list. IMHO it would be a desaster for other users if new Exclude folders will remove this folder in previous snapshots. About AIf you have no other suggestion I would say this is a documentation issue. The behavior is expected. But the GUI doesn't make it clear enough that the space-rule has higher priority than the smart-remove rules. From your users perspective do you have any suggestions how the snapshots dialog could be improved to make it clear enough? A simple text box is a bit to lazy. |
I can see how some people might prefer fresh snapshots over preserving history; so a solution for problem A would likely involve letting the user choose what has more priority, and maybe producing some warning when there is nothing left that is allowed to be deleted while there is still not enough free space left. As for problem B, I don't feel it's likely people would wanna keep excluded folders in old snapshots when --delete-excluded is active; but maybe there could be some reasoning I haven't thought of and might be wise to get more people's opinions on whether this should just be fixed in the form of deleting even retroactively, or provide the option to just exclude things on snapshots made after the addition to the exclude list. |
This would increase complexity of BIT. But why not just disable the space rule? Having not much space left is a rare case for most users. On the other hand there could be an option/behavior that BIT shouldn't start a new snapshot but warn if there isn't enough space left instead of removing old snapshots. We have an open issue (#569) about calculating the remaining space and showing it in the GUI. Also relevant #374. Also I found an old and still open Issue related to Problem A: #711 Can you suggest how the dialog should look like to indicate the real behavior? I don't like to much text in a dialog but can't imagine something else: |
I had assumed the behavior was
That should at least be something the user should be allowed to decide. Maybe add a second checkbox saying something along the lines of "Prioritize Smart Preservation over the other rules." Or if it turns out it's so dumb raw that Smart Remove actually just never gets used at all when the other options are enabled, not even leaving those exceptioned snapshots to be deleted last; then just gray it out altogether when any of the options that kills it is enabled. But again, for me it really makes sense that the options should all work together in harmony, with at the very least, an option to make "Keep" not just a "try to" thing, but actually a trustworthy promise. Slapping a warning that Smart Remove is superfluous, or doesn't have the last word; seems like a hacky solution, and it's basically just an admission that the bug exist and "it's not a bug, it's a feature". The original suggestion of just clarifying the bad behavior was a heat of the moment thing when I was still immediately pissed off the app deleted stuff it said it would keep. I really think this needs to be fixed and not just acknowledged (but until fixed, people should be made aware it won't really keep the stuff it says it will keep, maybe change the wording to "Try to keep*" and with the asterisk (or the whole trio of words plus the asterisk) in a highlighted color to let the user know it's not just text, explaining on hover what's the order of priorities when performing deletions, and maybe opening a help page when clicked that goes into more wordy details). Also, the presence of "Don't remove named snapshots" at the bottom seems to reinforce the idea that stuff bellow overrides stuff above. I'm not sure how to address that; maybe could be in a second column, on the same level as the first options? But again, that's just if you're gonna just slap a bandaid on it and not make things better. Or even that option also gets killed by the stuff above and also needs clarification? I don't think I had any named backups so dunno how it goes; I hope it's not the same dumb behavior, cause it sounds like something that would also really upset people if it turns out it's false promise as well. |
Thanks for your thoughts and insights. My own opinion is not a final decision. We need to discuss it in the team (here in this discussion thread). I don't see how to change the behavior. The point is that the smart remove rules are processed after each backup. The consequence is that all existing snapshots are "protected" by the smart remove rules. Maybe I don't see all details currently. About the named snapshots. I have to test it but to my knowledge of the code they are protected against all other rules. One of the bigger problems in BIT is that we do not have clear unit test for the rules and their combinations. Yes. This code indicates that named snapshots are deleted from the list of snapshots to delete. 😆 In short: Named snapshots are always protected. backintime/common/snapshots.py Lines 1902 to 1905 in d33f35e
|
So Smart Remove already removes things preemptively, and there is never anything left that fell out of the exclusions? Would it be possible to switch things around, and make it a filter for the Auto-Remove, making the Auto-Remove smart, as the current layout seems to imply; basically any snapshot protected by the Keep rules gets removed from the list of candidates the way it happens with Named Snapshots? Maybe keep the "Smart" word, but next to it, a drop-down that lets you select between "Remove" and "Preserve"; with Smart-Remove doing this preemptive deletion that is the current behavior, and "Smart Preserve" acting as this filter behavior I expected where it protects snapshots from deletion when the deletion functions get triggered and doesn't by itself perform any deletion? |
Though, with the dropdown approach; the "Keep" words there would still be somewhat misleading while in the Remove mode for anyone that don't look into it. Hm... Maybe forget about "Smart", and just have a drop-down that selects either "Instant Remove All Except:" and "Preserve:". And don't start the phrases with "Keep", so just "all snapshots for the last N days" and "one snapshot per *", so the the phrases make sense in both modes ? |
Btw: In #1107 there was also a discussion about re-design the dialog. |
That's my preference. If BiT or another application runs out of disk space, I want it to issue an error message and stop. Then I'll figure out what to do. |
In that issue & my description of how removal/retention works, I did point out that removal on the basis of space takes place after smart remove happens and not in the order that the options appear in the dialog. But even then I don't think I'd fully appreciated the undesirable consequences of running out of space. I don't think you should disable the "space" rule, there may be someone who wants it or uses it. I'd suggest either separating the smart from the non-smart options and make it very clear they operate independently, or even make them mutually exclusive. Then do what @daveTheOldCoder says: if BiT runs out of space and the space rule is not set, then stop with an error. |
Thanks. I will take that into account. |
Some possible replacements for "Smart remove": |
Or perhaps "Retention conditions". They are definitely conditions for retention, not removal. |
…sions (#1743, #1751) The global flock context manager (introduced in #1679) now fall back to single-user mode if permissions are insufficient to create an flock file accessible by other users and root. The multi-user mode will be activate later and automatically when BIT is started as root for the first time. It will create an flock file accessible by all users. That behavior is relevant for Arch-based systems but not relevant on Debian-based systems because regular users have enough permissions to /run/lock. Additionally fix a bug (introduced with #1679) ignoring the config value of `global.use_flock`. Additionally Sphinx config is modified and improved.. Fix #1743 Fix #1751
As for "Problem B": Our dialogs are already quite full of hints and warnings, but if I'm not mistaken, your problem would have been averted with a hint in the Exclude tab of the Settings that says something like: Excluding files and folders only affects future snapshots. For past snapshots, files and folders can be removed from the file viewer. |
I think it would help to replace the text "Smart remove" with something like "Remove all previous snapshots except". This would make it clear that the checkbox is enabling another reason for removal, with its own exceptions, rather than just adding the exceptions. |
Might not be directly relevant to this issue. But I investigated the current auto-/smart-remove behavior and documented it. I found inconsistent behavior and minor bugs. There is a lot potential to improve and refactoring. Before starting with this I would like to request your opinions and suggestions about the next steps. Please see the issue #1945 for details and a mockup for the new auto-remove dialog-tab. Feedback and suggestions welcome. We appreciate your feedback. |
I suggest adding an option to include this in debug/log output:
I added simple debugging code to do that when I was investigating #1094, and could provide that. |
Yes, I also had in mind to somehow illustrate (in the GUI) the process and the reasons of actions (remove/keep) taken. This way we could offer a dry-run for this, too. This is a lot of extra work. And I am not sure about the benefit. If the GUI and its documentation is simple and clear enough (in a prefect world) we wouldn't need such an illustration. But I will keep it mind while refactoring the code, so we have better opportunities to add a feature like this in the future. |
I assumed I could always count on the older snapshots sticking around. Then yesterday I fucked up and
mount --bind
a huge folder from another drive inside one of the folders that gets regularly backuped, and today I found out I just got the single backup made yesterday, no versioning for anything left :(I hope nothing important got wiped; but I do worry since there have been times I only discovered some days or even weeks later that I something got messed up and I managed to get it restored from the version from a few snapshots ago....
ps: I am already beating myself for not keeping up with 3-2-1, no need to pour any more salt on that wound
The text was updated successfully, but these errors were encountered: