Γιώργος Πάλλας posted on Sun, 28 Feb 2016 10:17:38 +0200 as excerpted: > On 28/02/16 05:45, Duncan wrote: >> Γιώργος Πάλλας posted on Sat, 27 Feb 2016 13:45:03 +0200 >> as excerpted: >> >>> Hi all. >>> >>> If I have a btrfs subvolume 'subv' and then subvolumes subv/sub1, >>> subv/sub2, subv/sub3, is there a way to snapshot all the subv tree and >>> then recursively send it remotely? >>> >>> I think this would be the analogous of zfs snapshot -r, and then zfs >>> send -R. >> As a list regular and btrfs user myself, but not a dev... >> >> No idea about zfs and my own btrfs use-case doesn't use btrfs send/ >> receive either, so this is primarily from previous list posts, with a >> quick look at the (v4.4.1) btrfs-send manpage as well... >> >> Recursive send isn't yet supported, only one at a time. >> >> Based on a previous comment from someone who apparently looked at the >> code (but isn't a btrfs dev either), there's possibly some code for -r >> (recursive) already in the repo (or maybe it's simply a comment reserving >> the -r option?), but it doesn't work yet. >> >> However, it shouldn't be horribly difficult to hack up scripts that >> automate the otherwise manual recursive-send/receive for you, as I'd very >> likely do myself if I needed that functionality. =:^) >> > > Thanks for the reply Duncan. > > The problem with scripting the recursive process, as I understand it, > is that in the case of e.g. adding an identical file inside each one > sub subvolume, this file would have to be transmitted during send, so > many times as the number of the sub subvolumes, which of course is not > viable. Am I right? As I understand it, no. What you're looking for is the -c <clone-src> option. While there can be only one parent, many clone-sources are allowed. Send does transfer a bit more metadata for clone-sources than it does for parents, but where it finds a clone, it's just that metadata, not the whole file. I /suspect/, however, that running dedup on the clone-sources first, such that the sources do share reflinks with the sent subvolume, will increase the hit-rate on the clones. I suspect that if the same file is separately added, without dedup, so the sources have multiple copies, not a shared copy, btrfs send won't detect the dups at send-time because they're not reflinking the same extents and thus aren't, to btrfs, duplicates. The inline dedup patches now being processed should help in that regard, however, avoiding having to run a separate dedup later, as has been the case with dedup so far. -- Duncan - List replies preferred. No HTML msgs. "Every nonfree program has a lord, a master -- and if you use the program, he is your master." Richard Stallman -- To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html
