this post was submitted on 31 May 2026
13 points (100.0% liked)

Linux

65545 readers
214 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 7 years ago
MODERATORS
 

I ran compsize on my debian box. Most files on my btrfs drive are around 20 GB. Almost all are uncompressed. I have 6000 files and 221000 regular extents.

Is that too much fragmentation? The ideal case is 1 extent per file.

I am reading around 100 MiBps from the drive out of a theoretical max of ~119 MiBps on a 1 Gbps line.

edit: On a local read I am getting 130-150 MiBps which exceeds the 1 Gbps network. pv /path/to/file >/dev/null

edit 2: For reference, this is a WD Red 6TB drive from around 2018-2020. Max speed should be in the 200 - 250 MBps range.

I defragged a ~300 GB folder and deleted some unneeded files. Extents per file actually went up, but I think that's because the remaining files are heavily fragmented (many 70+ extents per file). Somewhat surprisingly, most/all of the defragged files still had 3-10 extents. Each file is under 2 GB.

Before: ~35 extents per file. After: 55 extents per file.

compsize /path/to/folder
Processed 2648 files, 145287 regular extents (145287 refs), 1 inline.
Type       Perc     Disk Usage   Uncompressed Referenced
TOTAL       99%      1.5T         1.5T         1.5T
none       100%      1.5T         1.5T         1.5T
zstd        19%      236M         1.1G         1.1G
top 7 comments
sorted by: hot top controversial new old
[–] just_another_person@lemmy.world 2 points 5 hours ago* (last edited 4 hours ago) (4 children)

There is no "normal" amount of fragmentation on modern filesystems that do things like CoW. That's kind of the point.

If you're reading and writing large files with a consistent amount of I/O, you're going to have a higher amount of fragmentation because of the nature of CoW. This is by design. This doesn't mean anything is wrong with the filesystem, just that peak performance soon after writing is not achieved. Btrfs ~~and ZFS~~ do online defrag and deferred scheduling of tasks for it to allow for EVENTUAL consistency as far as contiguous block forms go. The more free space you have, the sooner it will become cleaner.

Do you know the implications for wear on the drive (related to TBW [total bytes written] and write amplification) on a CoW / highly fragmented drive? I figure if they are planning on writing once, then moving the whole file to an empty space, that means ~2x the writes.

[–] Static_Rocket@lemmy.world 1 points 3 hours ago

Note: BTRFS defrag will result in a different copy at the end of the day. If you're using snapshots this will lead to increased utilization.

[–] non_burglar@lemmy.world 1 points 4 hours ago (1 children)

Btrfs and ZFS do online defrag

News to me for ZFS. Are you talking about the recently implemented rewrite? Because "defrag" isnt really what that does, it simply consolidates metaslab data to (possibly) free up low-use blocks.

Using ZFS fragmentation profile import/export and/or enabling dynamic gang headers can certainly help with high fragmentation.

[–] just_another_person@lemmy.world 1 points 4 hours ago

Oops, you're right. ZFS doesn't have that.

[–] BigHeadMode@lemmy.frozeninferno.xyz 1 points 5 hours ago (1 children)

Btrfs ... do online defrag and deferred scheduling of tasks for it to allow for EVENTUAL consistency as far as contiguous block forms go. The more free space you have, the sooner it will become cleaner.

Based on my research, this has to be requested by the user/OS. I don't think Openmediavault (Debian derivative) enables auto defrag out of the box. If I set this up manually, I definitely didn't enable it. You can run a defrag command online (while the system is running) or set the mount to do it automatically.

[–] just_another_person@lemmy.world 1 points 4 hours ago

It should be a default, but I can see why it would be disabled for SSDs to prevent using cycles unnecessarily. If you're using HDDs, check and see if it's enabled.

Either way, unless you're REALLY needing some minor performance improvements out of your disks, it shouldn't make a huge difference.