The Btrfs File-System Repair Tool Is Available

Posted by Michael Larabel on February 21, 2012

After writing about Btrfs LZ4 compression support and that the Btrfs FSCK tool wasn't available, it turns out that there is the new Btrfs repair tool, but it's not widely known and it's not recommended to ever use it -- at least at this stage.

As pointed out by Phoronix readers, from the btrfs-progs Git tree on Kernel.org is a new branch that was pushed a little more than one week ago. This new branch is called "dangerdonteveruse" (expanded: don't ever use [it]) and contains the ability to fix Btrfs file-systems.

From a Phoronix reader, "The fixing-fsck for btrfs is not missing or behind closed doors in any sense, it's just not advertised (as the only thing worse than an unmountable filesystem is a mountable filesystem with the data hopelessly garbled). That decision been completely vindicated by the number of people who come into #btrfs or posting on the mailing list about broken filesystems only after they've run btrfs-zero-log (a tool to fix one very specific problem) or btrfs-select-super (which destructively overwrites the other supers with the selected one: you get one shot)"

Over the current state of btrfs-progs proper, this "don't ever use" branch has new balance support commands for balancing chunks across drives and other RAID restriper work, a new sub-command parser, and most notably is the --repair option. The new btrfsck --repair option currently handles fixing errors in the extent allocation tree and block group accounting. The btrfsck program has also picked up an --init-csum-tree command that will replace the check-sum root with an empty one. This will clear out the CRCs but allow the Btrfs file-system to be mounted with the nodatasum mount option.

In order to test out this support, the btrfs-corrupt-block utility in btrfs-progs has picked up an -e option, which will corrupt the extent record by zeroing out the extent allocation tree records. There's also now a -E option to randomly corrupt the extent_root.

The last commit to the "dangerdonteveruse" branch was on 10 February, which comes in just shy of the Valentine's Day deadline. Btrfs is going production ready in Oracle Linux and other Linux distributions will likely follow suit in the coming months and years. Fedora 18 will likely make the move to Btrfs as the first mainstream/tier-one distribution as right now Fedora, openSUSE, Ubuntu, and others just have Btrfs as an alternate install-time option for the root file-system.

At this time there's no word when Chris Mason will recommend the new btrfs-progs use in mass / merge it to master. Until then, obviously use the new "btrfsck" at your own risk. There's also no word on when any other repair functionality will be added to this file-system checker utility. At least the code is finally available to begin repairing Btrfs file-systems if left in a bad state, after it's been a "work in progress" for what seems like ages. Btrfs has been in the mainline Linux kernel since 2009.

Discuss this article in our forums, IRC channel, or email the author. You can also follow our content via RSS and on social networks like Facebook, Identi.ca, and Twitter (@Phoronix and @MichaelLarabel). Subscribe to Phoronix Premium to view our content without advertisements, view entire articles on a single page, and experience other benefits.
Latest Hardware Reviews
  1. Sumo Lounge Emperor
  2. Gallium3D Continues Improving OpenGL For Older Radeon GPUs
  3. 15-Way Open vs. Closed Source NVIDIA/AMD Linux GPU Comparison
  4. Nouveau vs. NVIDIA Linux Comparison Shows Shortcomings
Latest Software Articles
  1. Intel Linux OpenGL Driver Leading Over Apple OS X
  2. The Cost Of Ubuntu Disk Encryption
  3. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
  4. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
Latest Linux News
  1. LLVM Clang 3.3 RC2 Is Ready For Testing
  2. AMD RadeonSI Gallium3D Begins Simple CL Demos
  3. Intel Shows Off GNOME3-Based Tizen Shell
  4. Linux Desktop Security Could Be A Whole Lot Better
  5. KDE 4.11 Will Be The Last Major KDE4 Workspaces Feature Release
  6. New NVIDIA Linux Driver Supports The GeForce GTX 780
  7. Chrome 28 To Offer More Speed Improvements
  8. Digia Announces "Boot To Qt" Project
  9. X.Org Libraries Hit By Round Of Security Issues
  10. Wayland's Weston Gets Output Scaling Support
  11. Raspberry Pi Gets New Wayland Weston Renderer
Latest Forum Talk
  1. Intel Shows Off GNOME3-Based Tizen Shell
  2. VIA KMS Driver Now Supports HDMI Output
  3. AMD RadeonSI Gallium3D Begins Simple CL Demos
  4. AMD Radeon R600 GPU LLVM 3.3 Back-End Testing
  5. Linux Desktop Security Could Be A Whole Lot Better
  6. Microsoft's zombie attacks Android (again)
  1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Motherboards
  5. Peripherals
  6. Processors
  7. Software
  8. Operating Systems
  9. All Articles
  1. Linux Benchmarking
  2. OpenBenchmarking.org
  3. Phoronix Test Suite