Ntfs2btrfs is a tool which does in-place conversion of Microsoft’s NTFS filesystem to the open-source filesystem Btrfs, much as
↫ Mark Harmstonebtrfs-convert
does for ext2. The original image is saved as a reflink copy atimage/ntfs.img
, and if you want to keep the conversion you can delete this to free up space.
An amazing piece of software that works on both Linux and Windows, and even, as described above, comes with the option of undoing the conversion if you so desire and haven’t removed the original image yet. Its developer, Mark Harmstone, of course stresses that while he thinks the tool is quite stable, he obviously makes no guarantees or claims about its stability. In other words, please don’t use this on sensitive data or in a production environment.
What makes this tool even more amazing is that you can combine it with two of Harmstone’s other tools to really pull some rabbits out of your hat. First, there’s his Btrfs driver for Windows, which, as the name implies, allows Windows to work with Btrfs-formatted drives. Second, and here’s where things get really spicy, there’s Quibble, his custom bootloader consisting of open source reimplementations of Windows’ own bootloader. Using these three tools together you can, if you’re lucky, boot and run Windows off a Btrfs drive.
That’s quite cool, and while perhaps not particularly useful due to its experimental nature, it’s still an awesome weekend project.
Cool beans. I find Microsoft’s bootloader inferior. to those on linux, at least in terms of features.
If the author shows up by chance: The FAQ doesn’t mention secure boot, but it’s one of the first questions that came to mind.
I assume you have to disable secure boot in windows? Do you handle secure boot at all?
I wrote a couple boot-loaders in the day (before UEFI). It’s not hard at all, At least for DOS devs calling BIOS interrupts is second nature 🙂
The first time I tried Linux it was in a DOS (Windows 95?) computer. Slackware with UMSDOS filesystem. No need to deal with repartitioning the disk that I couldn’t do because I wasn’t the only one using that computer. Linux was just installed in a directory in a FAT partition.
Without that I wouldn’t have dared to try. Nowadays it’s easier to test things with virtual machines.
LOL, this is the type of useless waste that happens when you let software engineers run wild without direction. His time, effort and energy would have been better spent on, you know, maybe modernizing/fixing the UNIX/Linux filesystem permissions (yes I know ACL’s exists, but no one uses them, and that’s exactly what I mean).
tuaris,
Better for you doesn’t necessarily mean better for the dev. Do you agree that what developers do on their own time is their own prerogative? I’m sure there’s lots of stuff I like to do that doesn’t mean much to other people 🙂
And I would not call this completely useless.
The “Windows New File Systems” (ReFS) never actually materialized. It would be the answer to modern reliability requirement like ZFS and BTRFS. And they only support it on the server today (as far as I know).
That makes BTRFS an excellent choice for Windows desktops, if it becomes easy and reliable enough.
And as you mentioned, secure boot is also important.
sukru,
BTRFS is a nice modern FS and for most users running single disk file systems I think it’s fine.
I’d really like to use it myself and I absolutely love the way it dynamically handles re-balancing! So awesome! However every time I revisit it in order to take advantage of the improvements over LVM+extfs I come across the same major problems over and over again. First of all raid 5/6 are still not officially stable yet, but even avoiding those BTRFS raid only offers data redundancy, but not operational redundancy.
Every other raid solution increases fault tolerance as you add redundant disks, such as RAID 6 able to handle double disk faults before risking failure. However many users are surprised to learn that it’s the opposite with BTRFS’s implementation: every disk you add to the raid you actually decreases the system’s fault tolerance. If you have four or five disks in your raid, you significantly increase the chances of a boot failure since a failure of any one of them will prevent booting 🙁
Unfortunately the devs don’t seem to care about bootup exceptions because from their perspective it’s a “feature” that lets them manually control recovery. But for production and other situations where downtime is undesirable this absolutely must be automatic! Until BTRFS fixes this, it’s unfit for purpose next to other raid solutions.
It’s technically possible to run BTRFS on top of another raid implementation like mdraid, but then you loose out of some of BTRFS’s benefits like rebalancing across different sized disks and FS integrity protection. BTRFS has strong selling points for me, but it’s not worth switching to BTRFS until they fix these raid issues….I don’t know if they will though. I’d contemplate writing my own if I could justify the effort, haha.
I agree, it’s a stupid (or ideological) decision.
But you can change in the file /etc/grub.d/10_linux (Ubuntu) the line
RUB_CMDLINE_LINUX=”rootflags=subvol=${rootsubvol} ${GRUB_CMDLINE_LINUX}”
into
GRUB_CMDLINE_LINUX=”rootflags=degraded,subvol=${rootsubvol} ${GRUB_CMDLINE_LINUX}”.
Then the system will boot, even if the mirror is degraded.
AnAmigian,
BTRFS has a genuinely great feature-set. Really I’m sold, but this has to be fixed!
Yeah, I’ve looked for workarounds like this, but IIRC it is officially unsupported for two reasons.
1) Administratively degraded boot, while permitting boot with missing disks, doesn’t touch the raid configuration and can therefor cause data loss if the missing disk returns on a subsequent boot. I’d agree this posses a serious risk. So it needs to be fixed rather than leaving users to sort it out manually..
2) BTRFS lacks a feature that allows other raids to handle the above situation very well, which is a write map. If an active member goes missing and comes back, other raid implementations can use write maps to resync the member to a current state without completely rebuilding it. This feature is not critical to safe and reliable RAID operation, but it would be nice for BTRFS to achieve feature parity with mdraid.
I tested BTRFS again a few weeks ago because I’d really like to use it in my builds, but it’s so important to me to have a raid solution that protects against downtime. Every other raid solution I’ve ever used provides redundancy out of the box without any manual intervention. BTRFS don’t seem to respect the fact that manual intervention is downtime and potentially very significant downtime if you have a colocated server.. And it can be very inconvenient if you have to lug around a monitor and keyboard to investigate boot errors on a normally headless machine. Unfortunately BTRFS fails hard here as a raid solution….I’m so frustrated that the devs don’t care.
BTW, the reason I’m so attached to the subject is because I’m in the process of updating the custom linux distro I run on my own machines. I standardized on mdraid + lvm + extfs a long time ago but now I have to decide what to do over the next several years. On the plus side it works and has been robust. Disk failures have been mitigated perfectly as expected. On the minus side, it’s antiquated and the tools can be a bit cumbersome. LVM2 thin volumes were kind of hacked into LVM. Snapshots work, but because LVM and FS are separate layers extra care has to be taken to freeze the FS before snapshotting, etc.
BTRFS would be a welcome upgrade for modernization. But as it doesn’t pass the raid requirements. I’m left contemplating whether to go with a piecemeal approach like mdraid + BTRFS. The thing is I also use LVM to provide subvolumes for virtual machines, which BTRFS doesn’t support.
LVM handles “trim” operations from the guest, I don’t know if VM trim operations would propagate up to BTRFS files, which I need for thinly provisioned VMs. I had decided against hosting VM images inside of a file system many years ago because I found that routine fsck operations on massive host volumes took ages to complete. LVM volumes offered the solution. This is TBD with BTRFS.
If it came down to it, I could go with mdraid + LVM + btrfs, but at that point it’s not really worth it to me. These are the points I’ve been debating with myself, haha.
@Alfman
I am fascinated that you maintain a custom Linux distro. Is it a modified version of something else or did you really roll your own? Can you share a few lines on why?
LeFantome,
Well, it depends on the version of it. V1 started around 2004 and was heavily based on debian, but a few years later V2 was started from scratch. Or to be clear, I used loads of 3rd party sources and created a framework to build it all into a bootable image that wasn’t really based on anything else.. I can’t stress enough the value of automating everything when you undertake this kind of project by yourself. So the vast majority of the code is not originally mine with the exception of some local patches, a bootloader, and init system. I also wrote numerous helpers, but these are little more than thin wrappers for other tools to try and make them fit my usability needs.
I was young and naive…haha.
Actually there were a couple reasons, but it was mostly about tailoring a minimalist distro for headless server operation. I wanted something I could plop onto a thumb drive, boot up and provision quickly and remotely without having to babysit a typical installer. It comprised of a squashfs root that was small enough to run entirely from a ram disk, which made it blazing fast like no other distro.. Also it was robust…I can wipe out the file system, reboot and everything is reinitialized automatically. Data can be persisted using external mount points, but the OS itself is designed to be stateless (kind of like a CDROM based distro). It does check for configuration files, but if these are deleted it reverts back to provisioning. There was no GUI as it was designed for servers/routers/nas systems. It automatically opened VPN and SSH in addition to misc services like HTTP so it can be remotely provisioned without a display or keyboard. My distro isn’t comprehensive, but it does run other more standard distros inside of virtual machines, which can be connected to the network or VNC if needed.
Honestly this works great on x86 hosts. I wish it could as well on ARM computers but I’ve found the lack of ARM standardization and need for system specific images and deployment methods to be a real downer. On x86 I am typically able to boot & run my distro without stressing over vendor incompatibilities. ARM will probably never catch up on this front.
Anyway, as it relates to this discussion, my servers use mdraid+lvm+extfs and I am contemplating btrfs for future deployments, but I am disappointed with it in it’s present state.
ACLs are rarely used because for 99.9% of use cases the existing permissions are “good enough”…
For the core OS binaries you want them readable by all users and only writable by root.
Sensitive files like shadow you only want readable by root.
User files you only want readable by the user who owns them.
The use cases where you benefit from ACLs rather than suffering from the extra complexity are very niche.
bert64,
For single user systems, sure…but for multiuser systems I have to disagree. The old POSIX u/g/o file permissions are inadequate for group management in enterprise. And even though linux file systems have supported ACLs for a long time, I’d agree with tuaris that the userspace tooling for it remains lacking.
I really struggled to do what I wanted with *nix permissions when I transitioned to linux and even today it pains me to admit it but windows does it better. I’d love to do away with those posix bits altogether and I even tried to do this with my linux distro. The kernel itself doesn’t care, which is great, but a surprising amount of unix software hard codes logic dealing with these bits and it created barriers for switching to ACLs exclusively.
Why do you think it is wrong for someone to follow its curiosity? Economy is not an end. Happiness is my goal and curiosity is my guide.
How does “modernizing/fixing the UNIX/Linux filesystem permissions” do anything for Windows users?
From the point of view of a Windows user, the ability to use an exciting new COW filesystem that is receiving more active development than NTFS and is more open than ReFS could be seen a good thing. Whereas, from the point of a view of a Windows user, all the work going into Linux is “useless waste that happens when you let software engineers run wild without direction”.
unfortunately, I would take caution with these, as NTFS2BTRFS hasn’t been updated since March 2023, Quibble hasn’t since May 2023, and WinBTRFS since May 2024. is Mark still working on any of this?
You are looking at the releases. If you look at the commits, which is what shows if the project is actively being developed:
– ntfs2btrfs was last updated 4 days ago
– the BTRFS driver was updated last month
– quibble was updated 6 months ago
as far as your typical windows user is concerned, if there’s no build release, it hasn’t been updated.
Pretty sure ReactOS can boot off BTRFS. I believe it’s the interim filesystem between the limited FAT32 and the end goal of booting from NTFS. BTRFs provides a lot of NTFS like features without the hassle of writing drivers (as is mentioned here, they already exist) or reverse engineering proprietary ones.
Theoretically ReactOS aims to be kernel level compatible, so you should be able to load and use existing drivers at least until they can be replaced with open source ones.
I have never really gotten ReactOS to work with Btrfs. It installs ( though often “pauses” during install ) but always seems to suffer some kind of corruption after minimal use. My assumption is that it taxes some immature part of the ReactOS kernel too heavily.
Having a file system like Btrfs will be an important component of a viable system if ReactOS ever reaches usable status though.
“immature part of the ReactOS kernel too heavily.”
So all of it? The issue really is that reactos internals get rewritten every 5 years without getting much better…. I mean its just as crashy as it was a decade ago.