From: Hans van Kranenburg <hans.van.kranenburg@mendix.com>
To: Andrei Borzenkov <arvidjaar@gmail.com>,
dsterba@suse.cz, Anand Jain <anand.jain@oracle.com>,
Nikolay Borisov <nborisov@suse.com>,
linux-btrfs@vger.kernel.org
Subject: Re: [PATCH v4] btrfs: Remove received_uuid during received snapshot ro->rw switch
Date: Fri, 6 Oct 2017 23:27:01 +0200 [thread overview]
Message-ID: <ec221e1c-3cac-d35b-2bb9-fe66675b106e@mendix.com> (raw)
In-Reply-To: <e118b4e4-fd52-6ac3-0446-1dd5a7976544@gmail.com>
On 10/06/2017 10:07 PM, Andrei Borzenkov wrote:
> 06.10.2017 20:49, Hans van Kranenburg пишет:
>> On 10/06/2017 07:24 PM, David Sterba wrote:
>>> On Thu, Oct 05, 2017 at 05:03:47PM +0800, Anand Jain wrote:
>>>> On 10/05/2017 04:22 PM, Nikolay Borisov wrote:
>>>>> Currently when a read-only snapshot is received and subsequently its ro property
>>>>> is set to false i.e. switched to rw-mode the received_uuid of that subvol remains
>>>>> intact. However, once the received volume is switched to RW mode we cannot
>>>>> guaranteee that it contains the same data, so it makes sense to remove the
>>>>> received uuid. The presence of the received_uuid can also cause problems when
>>>>> the volume is being send.
>>
>> Are the 'can cause problems when being send' explained somewhere?
>>
>
> If received_uuid is present, btrfs send will use it instead of subvolume
> uuid. It means btrfs receive may find wrong volume as differential
> stream base. Example that was demonstrated earlier
>
> 1. A -> B on remote system S. B now has received_uui == A
> 2. A -> C on local system. C now has received_uuid == A
> 3. C is made read-write and changed.
> 4. Create snapshot D from C and do "btrfs send -p C D" to system S. Now
> btrfs receive on S will get base uuid of A and will find B. So any
> changes between B and C are silently lost.
Ah ok, yes, so the 'also' in that sentence just needs to go away. When
there are any modifications, it CAN NOT keep the received_uuid or bad
things will happen. and that's why this whole thread was started.
>>>>
>>>> Wonder if this [1] approach was considered
>>>> [1]
>>>> - set a flag on the subvolume to indicate its dirtied so that
>>>> received_uuid can be kept forever just in case if user needs it for some
>>>> reference at a later point of time.
>>>
>>> Yeah, we need to be careful here. There are more items related to the
>>> recived subvolume, besides received_uuid there's rtransid and rtime so
>>> they might need to be cleared as well.
>>>
>>> I don't remember all the details how the send/receive and uuids
>>> interact. Switching from ro->rw needs to affect the 'received' status,
>>> but I don't know how. The problem is that some information is being lost
>>> although it may be quite important to the user/administrator. In such
>>> cases it would be convenient to request a confirmation via a --force
>>> flag or something like that.
>>
>> On IRC I think we generally recommends users to never do this, and as a
>> best practice always clone the snapshot to a rw subvolume in a different
>> location if someone wants to proceed working with the contents and
>> changing them as opposed to messing with the ro/rw attributes.
>>
>> So, what about option [2]:
>>
>> [2] if a subvolume has a received_uuid, then just do not allow changing
>> it to rw.
>>
>
> What is reason behind allowing change from ro to rw in the first place?
> What is the use case?
I think this is a case of "well, nobody actually has been thinking of
the use cases ever, we just did something yolo"
Btrfs does not make a difference between snapshots and clones. Other
systems like netapp and zfs do. Btrfs cloud also do that, and just not
expose the ro/rw flag to the outside.
Personally, I would like btrfs to go into that direction, because it
just makes things more clear. This is a snapshot, you cannot touch it.
If you want to make changes, you have to make a rw clone of the snapshot.
The nice thing for btrfs is that you can remove the snapshot after you
made the rw clone, which you cannot do on a NetApp filer. :o)
>> Even if it wouldn't make sense for some reason, it's a nice thought
>> experiment. :)
There we go :)
--
Hans van Kranenburg
next prev parent reply other threads:[~2017-10-06 21:27 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-09-26 14:27 [PATCH 1/2] btrfs: Abort transaction if btrfs_update_root fails in btrfs_ioctl_subvol_setflags Nikolay Borisov
2017-09-26 14:27 ` [RFC PATCH 2/2] btrfs: Remove received_uuid during received snapshot ro->rw switch Nikolay Borisov
2017-09-27 8:53 ` [PATCH v2] " Nikolay Borisov
2017-09-26 17:39 ` [PATCH 1/2] btrfs: Abort transaction if btrfs_update_root fails in btrfs_ioctl_subvol_setflags David Sterba
2017-09-27 8:48 ` Nikolay Borisov
2017-09-27 14:00 ` David Sterba
2017-09-27 14:28 ` Nikolay Borisov
2017-09-28 7:53 ` [PATCH 1/2] btrfs: Explicitly handle btrfs_update_root failure Nikolay Borisov
2017-09-28 7:53 ` [PATCH v3 2/2] btrfs: Remove received_uuid during received snapshot ro->rw switch Nikolay Borisov
2017-09-29 17:56 ` David Sterba
2017-09-29 19:15 ` Nikolay Borisov
2017-10-04 15:00 ` David Sterba
2017-10-05 8:22 ` [PATCH v4] " Nikolay Borisov
2017-10-05 9:03 ` Anand Jain
2017-10-06 17:24 ` David Sterba
2017-10-06 17:49 ` Hans van Kranenburg
2017-10-06 20:07 ` Andrei Borzenkov
2017-10-06 21:27 ` Hans van Kranenburg [this message]
2017-10-07 7:56 ` Andrei Borzenkov
2017-11-12 17:11 ` Hans van Kranenburg
2017-09-29 17:42 ` [PATCH 1/2] btrfs: Explicitly handle btrfs_update_root failure David Sterba
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=ec221e1c-3cac-d35b-2bb9-fe66675b106e@mendix.com \
--to=hans.van.kranenburg@mendix.com \
--cc=anand.jain@oracle.com \
--cc=arvidjaar@gmail.com \
--cc=dsterba@suse.cz \
--cc=linux-btrfs@vger.kernel.org \
--cc=nborisov@suse.com \
/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;
as well as URLs for NNTP newsgroup(s).