What is BTRFS?

  Рет қаралды 32,059

The Linux Cast

The Linux Cast

Күн бұрын

Пікірлер: 224
@TheLinuxCast
@TheLinuxCast Жыл бұрын
This video was released early for my supporters! patreon.com/thelinuxcast and ko-fi.com/thelinuxcast
@vladimir_fomin90
@vladimir_fomin90 Жыл бұрын
in Linux Mint btrfs is configured out of the box!
@cannaroe1213
@cannaroe1213 7 ай бұрын
i really like the car insurance analogy, because in some ways having car insurance is like having a backup car, but you also know sometimes the insurance company doesn't pay out hahah
@pinchtwo654
@pinchtwo654 Жыл бұрын
I’ve only ever used ext3 and ext4 and I’ve been curious about btrfs. This was really informative for me. Appreciate it
@morpheon_xyz
@morpheon_xyz Жыл бұрын
Only used ext4 on my Linux systems, so defs has been informative for me too
@thesaigoneer
@thesaigoneer Жыл бұрын
One additional note: Siduction and Garuda also use Snapper/btrfs ootb. Great vid, thanks Matt!
@TheGhostOfRandy1-2-3
@TheGhostOfRandy1-2-3 11 ай бұрын
Garuda user here, btrfs really causes more problems than it is worth. I don't think the development team have ever had a handle on it....more of a quirk in their minds.... something to look modern and flash.
@Alex_whatever
@Alex_whatever Жыл бұрын
Thank you for this! I hope you are able to go through with the mentioned tutorial videos! It can be quite daunting to understand how to properly set things up so you can take advantage of the snapshot feature.
@nunyobiznez875
@nunyobiznez875 Жыл бұрын
I have had an unrecoverable disaster from BTRFS before. All I can say, is NEVER use the so-called repair utility. Whatever the problem, it will make it worse (though presumably it will be finished and work right someday). Use the scrub tool instead first, which will actually fix most common issues. In my case, it was a checksum mismatch after a crash, which should have been a minor problem, that could have been easily repaired by the scrub tool, had I known before hand. The repair tool just deleted the file and left the bad checksum, so the error could never be resolved, and with a fs error, BTRFS will only boot read-only. But, I live and learn, and despite this experience, I still use BTRFS for my root system.
@cenewton3221
@cenewton3221 Жыл бұрын
I've been using BTRFS w/ Snapper on my Garuda Dragonized/Hyprland daily driver for the past 6 weeks or so. Haven't HAD to use it yet but did test it out once & it worked perfectly. Using Vorta/Borg for my traditional backups. Good job on the video Matt, it's not an easy thing to explain in non-techie terms but you did it well. I've also never had any problem with BTRFS. One last thing though is Snapper/Snapper-Tools & Timeshift are in conflict with each other and you can only use one or the other. Garuda installs Snapper/Snapper-tools automatically when BTRFS has been chosen as the file system on initial install.
@advaitc2554
@advaitc2554 Жыл бұрын
You did a great job explaining. Thx! 😊 I'm eager to watch any and all videos you make about Btrfs and related topics.
@Neumah
@Neumah Жыл бұрын
BTRFS and snapper are part of why my experience with OpenSUSE Tumbleweed has been the greatest Linux experience I've ever had. I had one update bork my system and another time I borked it. Both times rolling back was a breeze, even the first time I ever did it it was easy. Had it been any of my previous distros I would have had to reinstall the OS due to lack of knowledge about how to fix it. I'm thoroughly on the Tumbleweed shill train.
@bstar777777
@bstar777777 Жыл бұрын
Every modern Linux install should have this capability using BTRFS or not.
@tambuchalinux
@tambuchalinux Жыл бұрын
I think that will be more common in later distros. I noticed the latest Manjaro had it preinstalled when I tried it out with btrfs filesystem. I actually didn't notice it in the grub menu until I manually edited it for tidyness..lol.
@gassug2
@gassug2 Жыл бұрын
btrfs isn't exclusive to tumbleweed. you can use btrfs on any distro that supports it, most of which these days will. i'm not saying tumbleweed is bad, i'm just saying it's odd that you hold tumbleweed in high regard for what is ultimately a btrfs feature and not a tumbleweed one. openSUSE just defaults to btrfs as the filesystem.
@Neumah
@Neumah Жыл бұрын
@@gassug2 If you read carefully you'll see that I said "part of" why Tumbleweed is so great. It's far from the one and only reason. Also, currently (or at least when I installed Tumbleweed) BTRFS doesn't come setup with Snapper properly out of the box on every distro that supports it. I've only heard of very few. And it being correctly setup out of the box is part of why it's great. Rollbacks are immediately available.
@timfd.w.4163
@timfd.w.4163 Жыл бұрын
Very nice video. Allow me just one tiny comment... About backups regarding alleged unstability I will add that EVERY system needs backups no matter the file system is stable.
@TheLinuxCast
@TheLinuxCast Жыл бұрын
Truth
@Derpingtonshere
@Derpingtonshere Жыл бұрын
*Writes note on forehead* Snapshots are backups. Okay got it.
@CotyTernes
@CotyTernes Жыл бұрын
I could be wrong, but from what I remember it was nicknamed "butter FS" was that it was supposed to be both "better" and faster/smoother, kinda like butter. So I heard a lot of "Better FS" and "Butter FS" when I was playing around with Linux a decade ago.
@CotyTernes
@CotyTernes Жыл бұрын
I should add that I was trying BTRFS out back then in the 2012-2014 area, and always had problems at that time. I was way more inexperienced with Linux back then. In the past 3 years every Linux computer I have set up I have used BTRFS and have had no issues with it. My Manjaro primary system has had it for almost 3 years on a single install (longest Linux install I've ever had) and still runs great!
@CotyTernes
@CotyTernes Жыл бұрын
@@binladen-ci7jm I very clearly said it was a nickname, not the actual name.
@CotyTernes
@CotyTernes Жыл бұрын
@@binladen-ci7jm This is just arguing semantics. They are nicknames, as people, whether through a misnomer or not, call it that. The name they call it is not the official established named, therefor it is a nickname.
@rodrigo.55
@rodrigo.55 Жыл бұрын
​@@binladen-ci7jmhave you ever heard of neologism? vernacular dialect? they would be considered misnomers but is not ugly, people just like to use it even being "wrong" and all.
@rodrigo.55
@rodrigo.55 Жыл бұрын
doesn't matter if it is "wrong"... if it sticks, it sticks. And I've to say, butterfs is much cooler.
@cejannuzi
@cejannuzi Жыл бұрын
Excellent video as an overview and introduction to BTRFS. Thank you.
@georgehope5477
@georgehope5477 Жыл бұрын
Oh great explanation. Going to have to look further into this.
@qball8up1968
@qball8up1968 Жыл бұрын
This was a crystal clear explanation of BTRFS. Very well done Matt.
@nietscherarek
@nietscherarek Жыл бұрын
Compression is also a killer feature.
@SpicyPoison
@SpicyPoison 3 ай бұрын
Those follow up videos are not yet out? I hope to see them soon. I was about to install Arch, but couldn't decide between ext4 and BTRFS.
@aelhamamy
@aelhamamy Жыл бұрын
Fedora needs some steps during installation to make sure its BTRFS system will work with timeshift, but after setup, it works like a breeze and gave me a great peace of mind. I believe it also needs root access to be enabled for recovering snapshots.
@esseindividuo
@esseindividuo Жыл бұрын
i got issues with btrfs caused by bad ram years ago, before i pinpoint the ram problem, the more i used the tools to fix corrupt data on btrfs more data got corrupted. didn't lost all files, just some files at random from the corrupted trees. i suggest that backups are made in different/maturer file systems.
@mjblcmichael
@mjblcmichael Жыл бұрын
That's the main reason I don't use BTRFS. I've heard similar stories as yours. I just stick with Ext4. It's never failed me yet. And I just use timeshift.
@chairman67
@chairman67 Жыл бұрын
me too..
@fumanchez
@fumanchez Жыл бұрын
Recently changed /home partition to btrfs with the compress=zstd:1 mount option, mainly to reduce the size of flatpak's .var directory, and it saves ~30% of the total space. And with compression you're mostly limited by compression speed - the speed of decompression is almost the same at all levels, so it might be worth using a higher compression level. Also take a look at how the openSUSE or Arch Linux installers (not based at Calamares) splits the root partition into subvolumes (if you want to use btfrs for this), e.g. it disables compression for /var.
@lsatenstein
@lsatenstein Жыл бұрын
I use zstd:2 where you are using zstd:1. For some directories I went with zstd:9. My reference partitions and my backup disk.
@MH_VOID
@MH_VOID Жыл бұрын
I mount all of my BTRFS partitions with compress-force=zstd:15 and I'll never go back. So fucking worth it. Only wish BTRFS supported even higher compression levels, and that I could defrag everything to forced zstd 15... Currently my root partition as a whole has a 58% compression ratio (108G used, 187G uncompressed, 406G referenced, 100G zstd-compressed down to 21G). My home partition has a 75% total compression ratio with its zstd compressed files compressed down to 39% average. For a particularly well compressed directory, my 50GB /logs directory consisting of 5700 files is zstd-compressed down to 5%, only taking 2.5G of space. My primary external hdd partition as of 2.5 months ago (the last time I ran a full partition compsize on it) has 77% total ratio, 44% average ratio for zlib-compressed files, and a 14% average ratio for zstd compressed files, saving over 1.1 terabytes of space by the zstd compression alone.
@fumanchez
@fumanchez Жыл бұрын
​@@MH_VOID interesting, but I use compression not so much, because I'm not sure about some things yet: a) isn’t the log file completely overwritten after appending a couple of lines to it? Theoretically, btrfs may compress the entire file on its modification. b) how much does the file access time decrease and how much CPU resources does it use? Does this affect the startup time of utilities like `ls` or even `[` or `test`, which all the scripts consist of? This can also drain your laptop battery. IMHO, there is no point in compressing the root partition and system files at all, since they are read very often and do not use so much space. Also Arch's pacman keeps already compressed downloaded packages in /var/cache.
@MH_VOID
@MH_VOID Жыл бұрын
@@fumanchez ​ > isn’t the log file completely overwritten after appending a couple of lines to it? The log file for what?? A sane program won't do this. > Theoretically, btrfs may compress the entire file on its modification. compression happens per extent (a 4KB (by default) contiguous physical chunk of storage). Each extent is 100% independent from the ones before and after it, I believe. This is how one file can have one part zstd level 9 compressed, another part lzo compressed, a third part not compressed at all, a 4th part zstd-15 compressed, and so on. If the extent is not modified, BTRFS won't change its compression unless you run a defrag on it. > how much does the file access time decrease and how much CPU resources does it use? Not enough for me to notice any problems. I just dd'd a 9.3GB log file located on my SSD (for maximum throughput) and compressed all the way down to 3% size (!) and monitored the BTRFS processes' CPU usage and the highest it ever reached was a whopping 0.2%. When you take into account that my CPU has 32 threads, that would mean about 6.4% usage of a single core in a highly demanding decompression task. Pretty damn acceptable in my book for 3300% space savings! And yeah most of the time you won't be getting savings that high, but then again most of the time you won't have a CPU cost that high either. Also keep in mind that if your hard drive read/write speeds are low, this can actually INCREASE the speed at which you read the files, as you can fetch more data at a time from the storage device. If you have a high end SSD and a bad CPU, yeah, you'll be losing out, but otherwise you are quite possibly gaining in total access time, even if time to first data availability will never be faster. > Does this affect the startup time of utilities like `ls` or even `[` or `test` I don't see why it would. The file data is compressed if possible, not its metadata. so `cat` would be slower but `ls`, `[`, `stat`, et cetera should be unaffected. > which all the scripts consist of? Which scripts? > This can also drain your laptop battery. I mean, yeah I guess the compressing and decompressing has an impact on battery life, but probably not one really all that significant, especially one significant enough to not be worth the space savings. Also keep in mind that the kernel will cache the files in memory if they're being frequently accessed, thereby making this less of an issue (For your executable question from before, I think they're often kept in memory so if you e.g. have an ls process running and then run another ls, the second ls won't access the disk at all to fetch its own data. And besides, even if it did, they're pretty small so the overhead would be rather negligible). There's also a counterpoint to be made in that less data is being physically written to storage and so some battery savings (in addition to the obvious throughput and space savings) are being had. > IMHO, there is no point in compressing the root partition and system files at all, since they are read very often and do not use so much space. Binaries actually compress extremely well. Right now, my /usr/bin directory is compressed down from 2.0G to 615M. In fact, only 8.9 megabytes across all those executables (and /usr/bin/ is symlinked to /bin and /sbin, so it's really pretty much all of them besides Rust programs I have in a separate directory) were deemed incompressible by compress-force=zstd:15, and so I have 332% space savings there for like no effort. See my previous point about caching too. Also, it's really nice for preventing random log files from filling up your entire hard drive because of some error their program had, causing other programs to fail with ENOSPC - even if you catch it quickly, it's still a pain. You don't really even need to rotate log files anymore, as they're compressed already to a similar extent. And as I said, in my personal case, > Also Arch's pacman keeps already compressed downloaded packages in /var/cache. So those files are deemed incompressible and are exactly the same as if you never enabled compression in the first place. There is 0 loss besides the minor one time cost of BTRFS trying to compress it when you first download them. Oh and as a final point, if you really don't want to deal with any significant additional latency, don't use a high level of zstd and instead use either a low level (1-3 I think) of it or use lzo, where these are made to be realtime. And also then don't mount with compress-force (which will always try to compress every single extent), and mount with just compress (which will try to compress the beginning of the file, then if it can't do so, just write the entire file as-is without compression). I personally would never do that, but you might find it useful, and there's really pretty much absolutely 0 downsides doing that as opposed to having no transparent compression whatsoever. I hope this helps
@icollided
@icollided 26 күн бұрын
Great video. I'm still new to BTRFS. So far, I think of snapshots as a "system configuration preset manager" and exclude data that is frequently changing like /home, hosted websites, or databases. I use rsync with a daily chron job to backup that stuff. Is my way of doing it a good idea?
@John7No
@John7No Жыл бұрын
Nice video, just a suggestion, maybe some visual elements as you were going through different things might be useful for newcomers. As far as a tutorial for btrfs that would be interesting, don't really care which distro you choose, although as a fellow opensuse fan I would like to see some inputs if opensuse does it differently than Arc. eg. if restoring on Arch is done by xyz , then a "flyby" short for opensuse would be nice. it would act as a comparison as well for people to see how far or close are 2 distros for the same concept.
@sentakuhm6519
@sentakuhm6519 Жыл бұрын
great video thank you very much, waiting for your tutorial about BTRFS.
@freyastears
@freyastears Жыл бұрын
I've been using btrfs on Arch for like a couple of years and never bothered to actually set it up properly so a tutorial would be very nice
@bstar777777
@bstar777777 Жыл бұрын
Unfortunately if you didn't setup your subvolumes properly then you will probably have to reformat. You took a sizable hit in performance vs EXT4 with no real advantages.
@freyastears
@freyastears Жыл бұрын
@@bstar777777 yeah probably, haven't noticed anything so far so I prob won't do anything for now lol
@MH_VOID
@MH_VOID Жыл бұрын
As a heavy BTRFS user, my last partition was created via `plz mkfs.btrfs --metadata dup --data dup --checksum blake2 --label 'reddit C&S' --verbose --verbose --verbose '/dev/sdb4' --force`. `alias plz=doas`. I mount it via `plz mount --options compress-force=zstd:15,async,datacow,datasum --label 'reddit C&S' /mnt/rdt`. Tools you should check out are duperemove (for deduping, example usage is `plz duperemove -vrdAh --dedupe-options=same --hashfile="${XDG_STATE_HOME}/duperemove/OLD__duperemove.sqlite3" -- /run/user/1000/no-atime_mb/BKP/ehdd`), and compsize (shows BTRFS file/directory {total,none,lzo,zlib,zstd} {compression ratio,disk usage,uncompressed size,referenced size}). Alias cp to `cp --reflink=auto` (or to `cp --reflink=always` if you want guaranteed reflinking but failure if it'd try reflinking something invalid (e.g. reflinking across filesystems, or on one that doesn't support it (mostly all except BTRFS, BCACHEFS, ZFS, XFS, and I think EXT4)). Personally I have it aliased to ` cp --reflink=auto --archive --verbose`). Periodically run duperemove over your BTRFS partition to free up space without data lossage (though note that it will reflink together files with intentionally-by-you identical but distinct underlying data, as obviously that's the point of it in the first place, so thereon if parts of one of those files is physically corrupted, all the copies will be corrupted as well), and scrub the filesystem every month or so (via e.g. `plz btrfs scrub start /dev/nvme0n1p2`) to detect and hopefully repair in time data corruption. Also (and this is assuming separate root, home, and other partitions) I highly recommend adding to your system update script/alias a command to snapshot your root filesystem (for mine, I appended `doas btrfs subvolume snapshot -r /mnt/defvol/_active/rootvol/ "/mnt/defvol/_snapshots/root-$(date --utc +'%Y-%m-%d--%H-%M-%S.%3N')"`), as that way if something goes wrong you can just `cp -t / /mnt/defvol/_snapshots/root-*(om[1])` or similar (Oh, you should also set it up so those root fs snapshots show up in your GRUB menu or similar so you could just boot directly into it if need be. I don't remember offhand how to do that, and I'd have to look it up with more effort than I care about to expend right now, so I won't elaborate further on this unless prompted by a genuinely interested party). That's basically it. I hope this helps you (or anyone else reading this, for that matter).
@gavrilloprincep
@gavrilloprincep Жыл бұрын
Thanks -- that was a very clear explanation and run through the issues you need to know about.
@MarkusHobelsberger
@MarkusHobelsberger Жыл бұрын
Subvolumes are actually a little like folders that contain hardlinks to all its files. You can have a look at them if you mount subvolid=5. 5 is usually the "parent" subvolume of a Btrfs file system.
@bjbboy71697
@bjbboy71697 Жыл бұрын
Been using btrfs for about 8 years now on Gentoo and I absolutely cannot go back to a file system that doesn't have snapshots. It's saved my bacon many a time and just makes using your computer way easier. I've even used snapshots to try out a desktop environment and then if i don't like it, i can just go back to my old snapshot like nothing ever happened. And i can't tell you how many times I've accidentally deleted a file i didn't mean to. Well, with btrfs I can just go into my latest snapshot and just cp that one file back over. Or say I just did a bunch of configuration changes and then I'm like aw shit I've made all these changes, but it's not working and i want to see what the defaults were again. Well i can just open up the old version of the file and have it next to my working copy and compare the changes i made. It's just beautiful!
@DimitrisVasil
@DimitrisVasil Жыл бұрын
Note: You can have snapshots on non-btrfs filesystems by using timeshift with rsync + hardlinks
@Flackon
@Flackon Жыл бұрын
I decided to try btrfs on Arch because I got sold on its features, but I’ve been having performance issues all the time. The system basically freezes when copying large files. I hope there’s some config tweak that I’m missing or something because if its gonna be like this I’m unlikely to use it ever again
@jhakonen
@jhakonen Жыл бұрын
I had freezes in Fedora as well with btrfs. I was able to fix those by using noatime in the disk's mount options. There's a note on that in btrfs's manual.
@afroceltduck
@afroceltduck Жыл бұрын
My big problem with BTRFS was how darn difficult it is to figure out how much data is stored where. It's not like EXT4, where you just run df -h and get a nice list of how much data is in each folder.
@Ghfvhvfg
@Ghfvhvfg Жыл бұрын
Understanding apfs is also dificult to its Feature Wise its similar to btrfs its just Apples Version of it......
@MH_VOID
@MH_VOID Жыл бұрын
Yeah, that's kinda the biggest downside of it. compsize is damn useful for that purpose though
@CyperN077
@CyperN077 9 ай бұрын
Matt on snap shots. It's better to have it and not need it than to need it and not have it. More on Arch btrfs please...
@leapbtw
@leapbtw Жыл бұрын
can you make a video about luks?
@BiserAngelov1
@BiserAngelov1 Жыл бұрын
I would like to thank the Garuda Linux, that made me appreciate the benefits of BtrFS, by forcing me to use it out of the box. It already saved my skin on two separate occasions.
@neusprach
@neusprach Жыл бұрын
Great video! Thanks for sharing!
@revazinikolashvili637
@revazinikolashvili637 Жыл бұрын
Fedora does nothing for btrfs snapshots. Just zstd compression, that's all they provide.
@MarkusHobelsberger
@MarkusHobelsberger Жыл бұрын
True. You have to install and set up snapper manually. Btrfs Assistant is another pretty useful tool.
@conceptrat
@conceptrat Жыл бұрын
Great explanation Matt ❤
@abdelmoneimelshafei6570
@abdelmoneimelshafei6570 Жыл бұрын
Great video , I want that tutorial about arch, and thanks for the video
@wolfpoker
@wolfpoker Жыл бұрын
I didn't understand the car insurance analogy, what do you mean "If I do go out"? :P
@arska-pelejavlogejajaautoj5030
@arska-pelejavlogejajaautoj5030 Жыл бұрын
Btrfs tutorial for Arch would be much appreciated.
@jeromecimino3879
@jeromecimino3879 27 күн бұрын
Garuda has snapper set up out of the box nicely as well.
@whydoyouaskdude
@whydoyouaskdude Жыл бұрын
For backups I use snap-sync to integrate snapshots on other drives with snapper, highly recommend.
@ssdemon96
@ssdemon96 Жыл бұрын
I use btrfs for my main drive and my secondary nvme ssd is using ext4 and is used just for games. I love the ability to rollback to a previous snapshot... currently running vanilla os and the btrfs setup is amazing.
@thedeemon
@thedeemon Жыл бұрын
In Manjaro I have btrfs and timeshift set up out of the box and I can see snapshots being made before each update. However I've never tried using those snapshots (there was never a need so far).
@fossface
@fossface Жыл бұрын
Please do a tutorial for btrfs on Arch. That is an excellent idea.
@ferd9438
@ferd9438 Жыл бұрын
Thank you very much for the effort of making this vid! It's very useful.
@alexsturm1799
@alexsturm1799 Жыл бұрын
Your explanations were good. Thank you.
@Merlin64-nb1tj
@Merlin64-nb1tj 7 ай бұрын
Best explanation I ever heard of BTRFS. 👍
@lqlarry
@lqlarry Жыл бұрын
👍 I wold love to see the Arch video, and I would also love to see what you have done in openSUSE with BTRFS. Thanks for the videos.
@Burgo361
@Burgo361 10 ай бұрын
I wonder how this interacts with wear levelling on ssds, it's a cool concept
@electric7487
@electric7487 Жыл бұрын
27:45 Yes! I would LOVE to see you do a tutorial on how to set up BTRFS, at least on Arch and Ubuntu.
@taukakao
@taukakao Жыл бұрын
This is missing why snapshots aren't backups: The data on the drive still only exist one time, so if the data on the drive corrupts, all files that point to that data will be corrupted. Rolling back to a snapshot won't help.
@justinhall3243
@justinhall3243 Жыл бұрын
I switched over from Ext4 to BTRFS on SUSE years ago and the only problem I ran into was my disk labeling tool could not deal with them so I had to learn a new way to name my drive "my disorganized crap"
@tambuchalinux
@tambuchalinux Жыл бұрын
Garuda has snapper, btrfs and grub snapshots out of the box. Although Garuda is great, I deleted in favour of CachyOS but I had to set it up manually with CachyOS. I wouldn't call it unstable either.
@Destide
@Destide Жыл бұрын
Why wouldn't you got opensuse at that point?
@tambuchalinux
@tambuchalinux Жыл бұрын
@@Destide I did try OpenSUSE. Zypper commands are unfamiliar..so are the package names. That package manager is also quite slow. I like CachyOS better. And I have snapper with btrfs-assistant enabled, so I can always revert back to an older snapshot if a new update breaks it.
@MarkusHobelsberger
@MarkusHobelsberger Жыл бұрын
Btrfs surely is the future for Linux' default filesystem. Apart from snapshots in my opinion compression is a very neat feature, too. Especially if you combine it with snapshots on a small disk to be able to store a lot more snapshots than without compression - I run a Fedora testmachine with only a 60 GB SSD like that. BUT I also think Btrfs needs a little more time and development before I'd want to replace the trusty and super-fast ext4 (fast_commit anyone?) on my main machines and especially on my data drives where I don't want a checksum error or some kind of other hiccup take down the whole drive. Running Debian based distros, I very rarely actually need to roll back a snapshot.
@MH_VOID
@MH_VOID Жыл бұрын
I'm a heavy BTRFS user with 15 terabytes or so of BTRFS partitions. I barely ever use snapshots. Transparent compression is an absolute game-changer (saving me terabytes of space), and so are reflinks, which I heavily use to the point that my partitions usually have like 3 times the referenced data as actual data, and which basically obsolete snapshots for me. The checksumming is also damn nice, and something I'd never go without (even for databases, I'm not going to nocow them since doing so disables the checksumming). I mount all my BTRFS partitions with compress-force=zstd:15, create them with blake2 checksumming (in the past, sha256 and xxhash, but blake2 mostly combines the benefits of both with few comparative downsides), and set dup data and metadata (halving my capacity but still actually coming out ahead when you consider the space savings from compression and reflinking). I will never voluntarily go back to any filesystem that does not have at a minimum reflinking, transparent compression, and extent/block/whatever checksumming (not having data & metadata duplication is fine, since I can always just set up RAID 10 or whatever) (oh and also xattrs and birth times. if it doesn't have that I'm not interested). The most likely thing to get me to move to a different filesystem is supporting even better compression - well, that, or actually doing away with the shitty path & file name limits.
@MarkusHobelsberger
@MarkusHobelsberger Жыл бұрын
@@MH_VOID Might I ask what kind of data you're storing that you can benefit that heavily from compression? From my experience big disks like that usually are mainly occupied by media files in the private environment. For me, for example, only about 5-10% of my data is reasonably compressable.
@georgehope5477
@georgehope5477 Жыл бұрын
So I could potentially recover from "rm -rf /*" right?
@TheLinuxCast
@TheLinuxCast Жыл бұрын
Some of it. But that would delete your home directory too which isn't a part of the snapshot.
@mariojpalomares2514
@mariojpalomares2514 Жыл бұрын
Linux mint distro is built for btrfs as it comes with timeshift included. Been using btrfs for 3 years on mint but never once have i touched timeshift tool even though it comes ready to use. But after watching this video, I will start using timeshift. Very informative. Also Linux mint takes care of the subvol for you when selecting btrfs. It set to add subvol by default in linux mint (maybe even ubuntu too). After 3 years not a single issue. It is stable even with kernel 6.2. Btrfs also performs better than ext4. Did some real world benchmark tests. This is why btrfs has been my default since then. In my experience i never once had a performance issue based on these claims. I have put this filesystem through its paces in a way that NTFS, ext4 got corrupted but btrfs is a champion.
@barfthebarf
@barfthebarf Жыл бұрын
Are you sure it doesn't roll off the tongue a little bit "butter"?
@praveenbharadwaj2059
@praveenbharadwaj2059 Жыл бұрын
Sir 0ls post a detailed video on timeshift and snapper
@Rockpat
@Rockpat 7 ай бұрын
Btrfs on Debian Testing (kinda Rolling Release Debian) is a Blessing. It saved my system after a weird Nvidia driver update breakage. (Upgrade from 525.xx to 535.xx) I think even Debian Stable Users should use Btrfs especially when they thinker with there system. Thanks for making the "not a tutorial" explanation Video about Btrfs.
@nomadic_shadow
@nomadic_shadow Жыл бұрын
I would like to see you set up btrfs in arch please
@kirangeorge8
@kirangeorge8 Жыл бұрын
Garuda sets up Btrfs out of the box
@jescis
@jescis Ай бұрын
And it's Arch based as well!! 😁😁😁😁
@kirangeorge8
@kirangeorge8 Ай бұрын
@jescis0 yup!
@MarioinRmd
@MarioinRmd Жыл бұрын
I got a short and cursory introduction to the BTRFS file system when I installed Garuda. Snapper was installed and activated out of the box. (Nice distro, BTW with a ton of features, but a little too much bling for me.) I mainly use Linux Mint and I trust those guys not to bork my machine. I have an ancillary drive with all of my important data, and I did take one snap shot with Time Shift shortly after I installed. If things go completely to poop, I look at it as an opportunity to switch distributions. Haha.
@MatthewSuffidy
@MatthewSuffidy Жыл бұрын
I generally get away with adding stuff to my system, but there have been some times I more or less regretting doing something. In some cases I just re installed everything which takes usually under a day. I would not personally like to use this sort of thing. One of the biggest problems was when I was looking for a vm that did pci passthrough and I thought boxes is what was available. It turned out after days of trying things that virtual manager just did it already, and very well. When I tried zen it made a complete mess of the system to the level I think it tried to boot linux as hypervised in the first place. Also I generally just turn off updates so I don't get into version problems, but I tried to update certain aspects of the system and then I had to update gcc and also the kernel to make it all work which was a disaster.
@repairstudio4940
@repairstudio4940 Жыл бұрын
Thank you, love 🧈 FS
@drrenard1277
@drrenard1277 Жыл бұрын
Yesss rolling updates. Gentoo user and btrfs has saved my behind
@Tzalim
@Tzalim Жыл бұрын
Garuda (Arch) Linux does BTRFS out of the box by default... You don't have to even touch it if you don't want to. It's the best file system in my opinion.
@avgGamer662
@avgGamer662 Жыл бұрын
I tried installing tumbleweed as 3rd os. I mounted already existing boot efi and swap, formated root as btrfs. But midway installation there was an error in mounting swap. I proceeded anyway. Now opensusse doesn't have swap
@RoelandJansen
@RoelandJansen Жыл бұрын
And making a swap is not easy? Takes you 5 minutes including coffee.
@TActually
@TActually Жыл бұрын
I love the idea of btrfs and snapshots, but since the performance of btrfs is still less than ext4, I'll just stick with rsync/timeshift, for now. Also.. YES, the setup for btrfs to be useful can be painful. Fedora doesn't set it up, at all, OOB. Apparently OpenSuse(according to you), Ubuntu(from experience) and Garuda(from experience) take care of just about everything for you.
@grxgghxrpxr
@grxgghxrpxr Жыл бұрын
It's kind of annoying how Fedora doesn't just call it @, instead they call the Root subvolume 'root', but it takes a couple of minutes to create a snapshot called '@' and change it in /etc/fstab.
@lsatenstein
@lsatenstein Жыл бұрын
If you had to copy a terrabyte of files to a terrabyte SSD, what do you think the difference between ext4 and BTRFS would be? Assume the latter is setup with zlib:2 compression. I bet it might be under 20 seconds in favour of ext4. But while the ext4 disk would be full, there would likely be one or two gigabytes available for the BTRFS disk.
@TActually
@TActually Жыл бұрын
@lsatenstein I don't use compression but, I get your point. You're saying the performance difference is negligible. The other kicker is that btrfs shortens the lifespan of your ssd, significantly and to store the backups on an alternate drive(for redundancy) you'd have to transfer the data the old-school way anyways. I think btrfs can be good for a lot of applications... it also is not the right choice for a lot of applications. Ext4 works for everything and doesn't require a ton of thought/setup/tooling.
@lsatenstein
@lsatenstein Жыл бұрын
@@TActually I am on my system 8 hrs per day, 5.5 days per week. At least twice a week I load up two Fedora beta ISOs , together with my other use, amounts to 5 gigs /week, onto a 120 gig SSD. That's been going on for 6 years for that SSD. I do keep about 25gigs reserved for BTRFS pages. Every 2 weeks I run a "fstrim" and a BTRFS compress. The BTRFS runs first to mark its reserved pages free. The fstrim does likewise for the SSD technology. I make use of two crontab entries that I set to run at 8am on alternate Fridays.
@lsatenstein
@lsatenstein Жыл бұрын
@@doesnotcompute6078 you are right about the cost of external storage. My external storage is a hard disk. Here compression on my desktop system is,😍 besides using less space, reducing I/O time.
@nerdycatgamer
@nerdycatgamer Жыл бұрын
Sounds like a great way to back up my data!! :)
@Qyngali
@Qyngali Жыл бұрын
Ihave to arrest you on the BTRFS is unstable bit, the only parts that are marked as such is RAID 5/6. There are a couple of features marked "Mostly OK",which obviously means minor. And most of those are also related to RAID. TLDR: If you run just a single disk there's nothing unstable about it. Paraphrased from the official status page. :) Edit: I'm posting link in a reply, so please move it from spam if it ends up there.
@mjblcmichael
@mjblcmichael Жыл бұрын
It sucks how we can't post useful links any more. Darn bots.
@Qyngali
@Qyngali Жыл бұрын
@@mjblcmichael yeah, I see it's gone. @TheLinuxCast if you could dig the post out of spam jail please. :)
@BUDA20
@BUDA20 Жыл бұрын
I started using BTRFS because I wanted to use zstd compression, It also has good drivers for windows, so is better than NTFS, to use in both systems (as a secondary drive for win)
@eniojurko
@eniojurko Жыл бұрын
I run endevour on btrfs(nvme), and have hdds for data and stuff, so for those hdds is it better to go also btrfs or ext4? What would be the recommendation?
@OcteractSG
@OcteractSG Жыл бұрын
“BetterFS” comes from the filesystem just being better than other filesystems. “ButterFS” is based on BTRFS using copy on write (COW) to enable atomic writes and snapshots. Butter comes from cows, so there you go. Both are used in everyday speech and they sound very similar to each other. Neither is wrong.
@budthecyborg4575
@budthecyborg4575 3 ай бұрын
I feel like Btrfs would wreck havok with the SSD controllers. Your SSD will perform differently as it fills up, "Free Space" is still used for write caching, if every file leaves a metadata pointer on the SSD you'd quickly end up with the SSD controller seeing a "full drive" even if your file system says it's half empty.
@jescis
@jescis Ай бұрын
Seems like an equivalent would be a snapshot liken to Windows Recovery partition while not necessarily the same… I have a separate HDD for backups and personal data…
@esra_erimez
@esra_erimez Жыл бұрын
20:57 Hey! What did I ever do to you? 🤣
@reklistube
@reklistube Жыл бұрын
As an arch user I would love a tutorial on using btrfs on top of encrypted volumes with luks
@rufine4114
@rufine4114 Жыл бұрын
liked the background blue light btw
@baeballeverwizard
@baeballeverwizard Жыл бұрын
Is btrfs the reason I can boot into an older kernel version when an update messes stuff up,or is that just a feature of grub/Linux in general?
@DanielCastro-ok8zb
@DanielCastro-ok8zb Жыл бұрын
That's on the distro, from what I understand. OpenSuse, for example, can't do that easily (or at all).
@Qyngali
@Qyngali Жыл бұрын
@@DanielCastro-ok8zb OpenSuse can have multiple kernels in Grub, no problem. Type "Opensuse multiple kernel" into your favorite search engine and see. :)
@bstar777777
@bstar777777 Жыл бұрын
BTRFS is pretty much required with Arch. I used it as a get out of jail card many times. Since switching to NixOS, snapshots are supported out of the box with any file system, so I prefer EXT4 again as I get a quite large bump in performance.
@NoahWatkins-p4z
@NoahWatkins-p4z Жыл бұрын
Arco Calamares still offers Snapper, both are superb. I have found my home in arco i3, first Arch and tiling wm and I am very happy to have chosen the combo.
@Rayyan-hi2ge
@Rayyan-hi2ge Жыл бұрын
It's also possible for windows to run btfs
@summerishere2868
@summerishere2868 Жыл бұрын
Btrfs is much much better at dealing with power loss than ext4. At least in my experience. Ext4 would easily fail at some point in time when doing fsck (after power loss). This reason alone is enough for me to prefer it over ext4. Also btrfs has been incredibly stable, I have been using it for almost 1 year.
@breadmoth6443
@breadmoth6443 Жыл бұрын
BTRFS is trying to be what ZFS is, sure you have OpenZFS for Linux, but Linus has no plans to include that into the kernel. When are people going to look at filesystems for NAND/NVMe drives? the ext*, XFS, JFS, BTRFS is all well and good but those filesystems are made for conventional disks in mind. I don't know of any distro that has JFFS2 as an option. Slackware AFAIK is the only distro that allows you to install on a F2FS filesystem which is made from the ground up for such devices - granted you can't boot off of it you need a regular ext* filesystem, but i guess it is better than nothing. My point stands though, considering more and more users are now using SSD or NVMe drives, it is time more distros look at F2FS or JFFS2 , though that seems to be the only filesystems available for Linux.
@breadmoth6443
@breadmoth6443 Жыл бұрын
@@Watcher4361 i guess this is the one time BSD is better, you can mix-and-match different licenses afaik , it has actual ZFS and not a re-implementation of ZFS
@Qyngali
@Qyngali Жыл бұрын
@@breadmoth6443At leastFreeBSD uses OpenZFS now.They migrated a couple years ago IIRC. Dunno about the other BSD variants.
@jamesyoung151
@jamesyoung151 Жыл бұрын
Garuda also uses brtfs by default as well.
@anafabula
@anafabula Жыл бұрын
Btrfs also has other advantages over ext4. For example filesystem compression, reflinks and raid
@TheLinuxCast
@TheLinuxCast Жыл бұрын
Yeah, I know I didn't cover any of that.
@oscs4556
@oscs4556 Жыл бұрын
Fedora does not have automatic snapshots, only fedora immutable versions do like fedora kiniote or silverblue.
@TheLinuxCast
@TheLinuxCast Жыл бұрын
Okay, so my regular versions of Fedora always did snapshots, I don't know why yours don't. They were performed at every Kernel update
@chris122380
@chris122380 Жыл бұрын
I've started using Garuda Linux and it also uses BTRFS and Snapshots by default. I like Garuda because it's based on Arch and has been working well for me so far. I have had troubles with OpenSuse and figuring out YAST with Wi-Fi.
@clusterguard
@clusterguard Жыл бұрын
EXT4 + Timeshift sounds more simple and solid to us simple mortals, man!
@AlexanderDeWolf-v7q
@AlexanderDeWolf-v7q 7 ай бұрын
Had major speed/latency issues on writes with many small files 4 years ago in RHEL 8 on lvm in a high volume production system. Had to move back to xfs. For personal use btrfs works well.
@bretvh
@bretvh 5 ай бұрын
How about saying its like a string?
@bretvh
@bretvh 5 ай бұрын
Are there defragmentation softwares available on linux for btrfs
@bretvh
@bretvh 5 ай бұрын
And are hypervisors for it
@bretvh
@bretvh 5 ай бұрын
Im on scsi
@tkenben
@tkenben Жыл бұрын
So, I watch the benchmarks DJ Ware does all the time and btrfs performs so bad on I/O tests compared to anything else, it's laughable, sometimes as low as half the speed of the competition. He'll often say off handedly when commenting on the benchmarks as they scroll by, "and then of course btrfs is last", as if this is just a given and common knowledge. Like with anything, I suppose that's the price you pay. Redundancy, safety, and security is not cheap.
@ifohancroft
@ifohancroft 10 ай бұрын
Nice! Now we can play Bash Russian Roulette on our own system.
@tekrocker
@tekrocker Жыл бұрын
TIP - if you pivot your monitor or the source light, you will get rid of that horrible glare WE all have to look at!!
@JB52520
@JB52520 9 ай бұрын
I didn't realize it was B-Tree FS. Binary trees are a lot of fun if you like data structures.
@classicrockonly
@classicrockonly Жыл бұрын
I use ZFS btw. I stopped trusting btrfs. I personally have not had issues using btrfs, but I saw a friend's computer spectacularly explode numerous times with him trying to use it. And I've known others who have had recent horror stories. And also, 16 years of development later and they still have all these issues? Doesn't inspire much confidence in me in the quality of the code
@andrem9175
@andrem9175 5 ай бұрын
very nice!
@RM-hn6ir
@RM-hn6ir Жыл бұрын
OpenZFS is better, especially if you have a complex set up of a lot of drives. I also like F2FS too.
@MH_VOID
@MH_VOID Жыл бұрын
I disagree, especially when doing non-RAID setups. I currently use BTRFS as my primary filesystem across 3 drives and like 6 partitions. I think bcachefs will likely be better than BTRFS though. I've never heard of F2FS, but looking it up briefly it looks interesting, though those are some godawful size limits it has (4TB max file size? I've gotten pretty close to that already. Same thing with the maximum of a 16TB large volume). Why do you state OpenZFS is better? AFAIK, it doesn't even have reflinks!
@Robert-sj8ld
@Robert-sj8ld 9 ай бұрын
👍🏻👍🏻👍🏻👍🏻👍🏻
@dagda825
@dagda825 Жыл бұрын
It seems as though btr is a more complicated version of timeshift from my "just works" mindset. If you aren't using something like timeshift I don't know what to tell you.
5 Reasons You Should Use Distrobox
20:55
The Linux Cast
Рет қаралды 26 М.
Stupidly Simple Note Taking
10:46
The Linux Cast
Рет қаралды 4 М.
Война Семей - ВСЕ СЕРИИ, 1 сезон (серии 1-20)
7:40:31
Семейные Сериалы
Рет қаралды 1,6 МЛН
Какой я клей? | CLEX #shorts
0:59
CLEX
Рет қаралды 1,9 МЛН
Hardware Raid is Dead and is a Bad Idea in 2022
22:19
Level1Techs
Рет қаралды 699 М.
OpenSuSE - You Should Try It
30:24
The Linux Cast
Рет қаралды 74 М.
Which Linux filesystem is best in 2022?
19:32
DJ Ware
Рет қаралды 78 М.
I Used Debian 12 For 5 Months - Long Term Review
46:13
The Linux Cast
Рет қаралды 131 М.
Where Did Arch Linux Come From?
16:21
Action Retro
Рет қаралды 148 М.
BTRFS | All You NEED to know!
23:48
Maple Circuit
Рет қаралды 13 М.
Why Are Open Source Alternatives So Bad?
13:06
Eric Murphy
Рет қаралды 735 М.
File Systems | Which One is the Best? ZFS, BTRFS, or EXT4
12:07
Chris Titus Tech
Рет қаралды 218 М.
The Most OVERRATED Linux Distros
20:48
The Linux Cast
Рет қаралды 75 М.
Война Семей - ВСЕ СЕРИИ, 1 сезон (серии 1-20)
7:40:31
Семейные Сериалы
Рет қаралды 1,6 МЛН