How much space to leave free on HDD or SSD?

110

31

In the informal (i.e. journalistic) technology press, and in online technology blogs and discussion forums, one commonly encounters anecdotal advice to leave some amount of space free on hard disk drives or solid state drives. Various reasons for this are given, or sometimes no reason at all. As such, these claims, while perhaps reasonable in practice, have a mythical air about them. For instance:

  • Once your disk(s) are 80% full, you should consider them full, and you should immediately be either deleting things or upgrading. If they hit 90% full, you should consider your own personal pants to be on actual fire, and react with an appropriate amount of immediacy to remedy that. (Source.)

  • To keep the garbage collection going at peak efficiency, traditional advice is aim to keep 20 to 30 percent of your drive empty. (Source.)

  • I've been told I should leave about 20% free on a HD for better performance, that a HD really slows down when it's close to full. (Source.)

  • You should leave room for the swap files and temporary files. I currently leave 33% percent free and and vow to not get below 10GB free HDD space. (Source.)

  • I would say typically 15%, however with how large hard drives are now adays, as long as you have enough for your temp files and swap file, technically you are safe. (Source.)

  • I would recommend 10% plus on Windows because defrag won't run if there is not about that much free on the drive when you run it. (Source.)

  • You generally want to leave about 10% free to avoid fragmentation (Source.)

  • If your drive is consistently more than 75 or 80 percent full, upgrading to a larger SSD is worth considering. (Source.)

Has there been any research, preferably published in a peer-reviewed journal, into either the percentage or absolute amount of free space required by specific combinations of operating systems, filesystem, and storage technology (e.g. magnetic platter vs. solid state)? (Ideally, such research would also explain the reason to not exceed the specific amount of used space, e.g. in order to prevent the system running out of swap space, or to avoid performance loss.)

If you know of any such research, I would be grateful if you could answer with a link to it plus a short summary of the findings. Thanks!

sampablokuper

Posted 2017-10-04T11:43:23.607

Reputation: 2 389

1Free space doesn’t have a performance hit if your using mechanical drives and how honestly the firmware on SSDs today are so efficient it isn’t true on them anymore – Ramhound – 2017-10-04T11:50:11.433

what I don't get is the SWAP argument. Why would I leave a percentage of the HDD's capacity, and not just 100% of the RAM's capacity? – Abdul – 2017-10-04T11:55:30.567

2I don't know about research findings, but I know about my own findings. There will be no performance penalty (apart from marginally slower directory accesses) on a nearly full drive if all its files are defragmented. The problem is that many defragmenters optimise file fragmentation, but in the process leave the free space even more fragmented, so that new files become immediately fragmented. Free space fragmentation becomes much worse as discs become full. – AFH – 2017-10-04T12:00:57.480

8@Abdul - A lot of the advice on swap file size is misleading. The key requirement is to have enough memory (real and virtual) for all the programs you want to have active at a time, so the less RAM you have, the more swap you need. Thus taking a proportion of the RAM size (double is often suggested) is wrong, other than as an arbitrary initial size until you find out how much you really need. Find out how much memory is used when your system is busiest, then double it and subtract the RAM size: you never want to run out of swap space. – AFH – 2017-10-04T12:12:37.410

Could you please add what filesystem/OS do you ask about. – enkryptor – 2017-10-04T13:03:57.293

1on swap, it should be at least as large as your RAM if you are going to hibernate the machine. This is because swap is where your memory contents are saved. Ideally, you want it bigger, so you can hibernate while using swap, if needed. – Baldrickk – 2017-10-04T14:48:24.870

1@Ramhound I doubt that. The less space left on the disk, the higher chance new files will be fragmented around and reduce performance – phuclv – 2017-10-04T16:31:59.397

10% HDD, 25% SSD. – PCARR – 2017-10-04T16:33:18.213

empties his trash can – Housemd – 2017-10-04T16:43:04.450

2I think this really depends on what you are using the drive for. If you need to add and remove tons of data from the hard drive in large segments, I would leave decent amount of free space based off of the size of the files you need to move around. 10-20% seems a reasonable general suggestion, but I have nothing to support that apart from personal experience. – David – 2017-10-04T18:47:27.357

@LưuVĩnhPhúc - I don't agree there is a huge hit on performance from file fragmentation on SSDs – Ramhound – 2017-10-04T18:59:07.200

2

@EugenRieck, see Jon Turney's "End of the peer show" (New Scientist, 22 Sept 1990). Peer review is known to be imperfect, but there are few better options. Even a mediocre & erroneous paper should be more falsifiable than a vague, passing claim in a blog or forum post, making it a better starting point for understanding.

– sampablokuper – 2017-10-04T19:13:27.520

@sampablokuper Please don't get me wrong - I don't want to declare a superiority of Stack Overflow over peer-review Money makers. If you want to write a paper for one of these journals, go with sources from these journals. But if you want to keep production systems alive and well, go with Stack Overflow. These two worlds share no overlap. – Eugen Rieck – 2017-10-04T19:18:23.023

@Ramhound I mean on HDD as you were saying "Free space doesn’t have a performance hit if your using mechanical drives". Anyway fragmentation will introduce a very small on SSD because instead of reading the whole giant extent on ext4 and NTFS, the driver now has to determine which block to read next – phuclv – 2017-10-05T02:32:26.960

1Important thing: if it is the drive where software constantly performs operations, e.g. C: with OS installed - you should care for a free space. If it is a storage drive - e.g. a drive with photos and videos - safely fill it up 100%. – Dima – 2017-10-05T10:49:28.830

2

@EugenRieck: "peer-review Money makers"; some publishers are more ethical than others. (In case you are wondering, yes I know the tragedy of U.S. v. Aaron Swartz.) "These two worlds share no overlap." Happily, they do. At universities & elsewhere, I see sysadmins & academics alike benefit from both SE & PR. Please let's stay on-topic now on, thanks :)

– sampablokuper – 2017-10-05T17:52:25.920

It's important to draw a distinction between the performance impact of a data storage disk being full and the impact of an operating system boot volume being full, especially for Windows OSes. The answers are completely different for the two scenarios. – barbecue – 2017-10-05T23:58:39.637

Answers

10

Has there been any research, preferably published in a peer-reviewed journal […]?

One has to go back a lot further than 20 years, of system administration or otherwise, for this. This was a hot topic, at least in the world of personal computer and workstation operating systems, over 30 years ago; the time when the BSD people were developing the Berkeley Fast File System and Microsoft and IBM were developing the High Performance File System.

The literature on both by its creators discusses the ways that these filesystems were organized so that the block allocation policy yielded better performance by trying to make consecutive file blocks contiguous. You can find discussions of this, and of the fact that the amount and location of free space left to allocate blocks affects block placement and thus performance, in the contemporary articles on the subject.

It should be fairly obvious, for example, from the description of the block allocation algorithm of the Berkeley FFS that, if there is no free space in the current and secondary cylinder group and the algorithm thus reaches the fourth level fallback ("apply an exhaustive search to all cylinder groups"), performance of allocating disc blocks will suffer as also will fragmentation of the file (and hence read performance).

It is these and similar analyses (these being far from the only filesystem designs that aimed to improve on the layout policies of the filesystem designs of the time) that the received wisdom of the past 30 years has built upon.

For example: The dictum in the original paper that FFS volumes be kept less than 90% full, lest performance suffer, which was based upon experiments made by the creators, can be found uncritically repeated even in books on Unix filesystems published this century (e.g., Pate2003 p. 216). Few people question this, although Amir H. Majidimehr actually did the century before, saying that xe has in practice not observed a noticeable effect; not least because of the customary Unix mechanism that reserves that final 10% for superuser use, meaning that a 90% full disc is effectively 100% full for non-superusers anyway (Majidimehr1996 p. 68). So did Bill Calkins, who suggests that in practice one can fill up to 99%, with 21st century disc sizes, before observing the performance effects of low free space because even 1% of modern size discs is enough to have lots of unfragmented free space still to play with (Calkins2002 p. 450).

This latter is an example of how received wisdom can become wrong. There are other examples of this. Just as the SCSI and ATA worlds of logical block addressing and zoned bit recording rather threw out of the window all of the careful calculations of rotational latency in the BSD filesystem design, so the physical mechanics of SSDs rather throw out of the window the free space received wisdom that applies to Winchester discs.

With SSDs, the amount of free space on the device as a whole, i.e., across all volumes on the disc and in between them, has an effect both upon performance and upon lifetime. And the very basis for the idea that a file needs to be stored in blocks with contiguous logical block addresses is undercut by the fact that SSDs do not have platters to rotate and heads to seek. The rules change again.

With SSDs, the recommended minimum amount of free space is actually more than the traditional 10% that comes from experiments with Winchester discs and Berkeley FFS 33 years ago. Anand Lal Shimpi gives 25%, for example. This difference is compounded by the fact that this has to be free space across the entire device, whereas the 10% figure is within each single FFS volume, and thus is affected by whether one's partitioning program knows to TRIM all of the space that is not allocated to a valid disc volume by the partition table.

It is also compounded by complexities such as TRIM-aware filesystem drivers that can TRIM free space within disc volumes, and the fact that SSD manufacturers themselves also already allocate varying degrees of reserved space that is not even visible outwith the device (i.e., to the host) for various uses such as garbage collection and wear levelling.

Bibliography

JdeBP

Posted 2017-10-04T11:43:23.607

Reputation: 23 855

6"Bibliography" is a tad useless without in-text references. – ivan_pozdeev – 2017-10-09T14:43:15.337

48

Though I can't talk about "research" being published by "peer reviewed journals" - and I wouldn't want to have to rely on those for day-to-day work - I can though talk about the realities of hundreds of production servers under a variety of OSes over many years:

There are three reasons why a full disk reduces performance:

  • Free space starvation: Think of temp files, Updates, etc.
  • File system degradation: Most file systems suffer in their ability to optimally lay out files if not enough room is present
  • Hardware level degradation: SSDs and SMR disks without enough free space will show decreased throughput and - even worse - increased latency (sometimes by many orders of magnitude)

The first point is trivial, especially since no sane production system would ever use swap space in dynamically expanding and shrinking files.

The second point differs highly between file systems and workload. For a Windows system with mixed workload, a 70% threshold turns out to be quite usable. For a Linux ext4 file system with few but big files (e.g. video broadcast systems), this might go up to 90+%.

The third point is hardware and firmware dependent, but especially SSDs with a Sandforce controller can fall back in free-block erasure on high-write workloads, leading to write latencies going up by thousands of percent. We usually leave 25% free on the partition level, then observe a fill rate of below 80%.

Recommendations

I realize that I mentioned how to make sure a max fill rate is enforced. Some random thoughts, none of them "peer reviewed" (paid, faked or real) but all of them from production systems.

  • Use filesystem boundaries: /var doesn't belong into the root file system.
  • Monitoring, monitoring, monitoring. Use a ready-made solution if it fits you, else parse the output of df -h and let alarm bells go of in case. This can save you from 30 kernels on a root fs with automatic-upgrades installed and running without the autoremove option.
  • Weigh the potential disruption of a fs overflow against the cost of making it bigger in the first place: If you are not on an embedded device, you might just double those 4G for root.

Eugen Rieck

Posted 2017-10-04T11:43:23.607

Reputation: 15 128

19This is helpful: it is more detailed, and has greater explanatory power, than the typical anecdote. I upvoted it accordingly. But I really want more solid evidence than just, "someone on the internet says that this is their experience". – sampablokuper – 2017-10-04T12:18:55.597

2I like to think while reading this answer, an important note is that there is no 'end-all' answer, and that you may find more details you were looking for by thinking about each use case. I definitely understood how to solve the problem better here when Eugen listed what significant processes might use that last available space. – Pysis – 2017-10-04T17:33:39.420

4The first point isn't trivial now that the systemd cancer has eaten most distros. /var fills up and your server falls over. – chrylis -on strike- – 2017-10-04T17:42:07.680

2@chrylis While I agree with you in the core of the problem, I tend to use a separate file system for /var and another for /var/log to even out the playing field. In addition to that, df monitoring is important - I ought to edit that into my answer – Eugen Rieck – 2017-10-04T18:38:28.653

You should point out that how much of your storage space you can use doesn't depend on the OS. One could currently interpret it like that. If you were to use NTFS on Linux for some odd reason, you probably shouldn't use 90% of your storage space, even through using 90% on an ext4 FS isn't a problem at all (with HDDs). – UTF-8 – 2017-10-04T19:18:06.020

@UTF-8 I understand your point - the only reason though to use NTFS on Linux that I can think of is Windows compatibility, and I wrote about Windows and a 70% rule of thumb earlier on. – Eugen Rieck – 2017-10-04T19:20:42.230

6Eugen Rieck--I hate to say but your answer is about a) what do you do; and b) why it is useful. I don't see any pointers toward relevant research, e.g. what happens if you fill more than 70% on a windows system. Note that the original question was about actual (not necessarily peer-reviewed) research. – Ott Toomet – 2017-10-05T04:55:27.937

1Keeping 25% unpartitioned and another 20% free on an SSD is completely pointless, even counterproductive. The underlying reason is that wear levelling on an SSD decouples physical and logical block numbers. The 25% unpartitioned space and 20% free inside the partition are both unused logical numbers, adding up to 40% unused logical numbers. It would be much better to partition 100% and leave 40% free. This gives the file system (dealing in logical numbers) more space to play with, while the SSD doesn't care at all. – MSalters – 2017-10-06T10:38:10.223

@MSalters It is not completely pointless - you just missed the point. Keeping 25% free on the partition level makes 100% sure, that even if the partitioned space runs full (for whatever reason) there is enough unused space for the GC in the firmware to provide free blocks timely on high write workloads. So while we reduce FS headroom, we get a 100% assured percentage of currently unused blocks for the firmware to play with. Since currently FW and controllers are much worse than file systems, this makes good sense. – Eugen Rieck – 2017-10-06T13:02:15.930

@chrylis Monitoring your /var/log for capacity was necessary even with Slackware 14 — which did not use SystemD. – can-ned_food – 2017-10-07T06:08:55.087

1@can-ned_food But you could boot into single-user mode, and your syslog usually didn't try to persist the kernel log at DEBUG level. – chrylis -on strike- – 2017-10-07T06:18:13.013

Interestingly enough no one has mentioned that that the bandwidth at the end cylinder is around half that of the start cylinder, so deliberately keeping your usage low would be of speed benefit. See https://en.wikipedia.org/wiki/Hard_disk_drive_performance_characteristics for references

– iheggie – 2017-10-08T05:32:05.633

@theggie Short-stroking has become rather obsolete - capacity (per $) is the single biggest advantage of HDDs over SSDs, so sacrificing some of that has become unusual. Bandwidth is also much less of a problem than latency: A simple 10-Disk RAID6 of spinning rust easily can hit 1GByte/s even on the innermost cylinders. – Eugen Rieck – 2017-10-08T12:03:11.577

6@sampablokuper Solid piece of advice for you: academic priorities are vastly different from day to day operations priorities. That's why your college degree didn't actually prepare you for this issue. Academics rarely care this much about the day to day practical problems of these systems. Always check your info for sanity, but aside from that, trust the people who actually successfully run these systems over some pie in the sky paper. You also have the benefit of having crowd sourced your info, which greatly reduces the likelihood that you're getting garbage info. – jpmc26 – 2017-10-09T09:36:04.543

29

Has there been any research...into either the percentage or absolute amount of free space required by specific combinations of operating systems, filesystem, and storage technology...?

In 20 years of system administration, I've never encountered research detailing the free space requirements of various configurations. I suspect this is because computers are so variously configured it would be difficult to do because of the sheer number of possible system configurations.

To determine how much free space a system requires, one must account for two variables:

  1. The minimum space required to prevent unwanted behavior, which itself may have a fluid definition.

    Note that it's unhelpful to define required free space by this definition alone, as that's the equivalent of saying it's safe to drive 80 mph toward a brick wall until the very point at which you collide with it.

  2. The rate at which storage is consumed, which dictates an additional variable amount of space up be reserved, lest the system degrade before the admin has time to react.

The specific combination of OS, filesystems, underlying storage architecture, along with application behavior, virtual memory configuration, etc. creates quite the challenge to one wishing to provide definitive free space requirements.

That's why there are so many "nuggets" of advice out there. You'll notice that many of them make a recommendation around a specific configuration. For example, "If you have an SSD that's subject to performance issues when nearing capacity, stay above 20% free space."

Because there is no simple answer to this question, the correct approach to identify your system's minimum free space requirement is to consider the various generic recommendations in light of your system's specific configuration, then set a threshold, monitor it, and be willing to adjust it as necessary.

Or you could just keep at least 20% free space. Unless of course you have a 42 TB RAID 6 volume backed by a combination of SSDs and traditional hard disks and a pre-allocated swap file... (that's a joke for the serious folks.)

I say Reinstate Monica

Posted 2017-10-04T11:43:23.607

Reputation: 21 477

8Thanks for the answer :) I'd like to take up one of your points: "It's not necessary to justify advice to leave some free space since the consequence of a storage depleted machine is self-evident." No, it isn't self-evident. It surprises people more than you might expect. And different combinations of operating system, filesystem, etc, are likely to respond to this situation in different ways: some might warn; some might fail without warning; who knows? So, it would be great to shine more light on this. Hence my question :) – sampablokuper – 2017-10-04T15:38:05.960

1When I assert it's self-evident there are consequences of a storage depleted machine, I'm not describing those consequences, but rather asserting that storage depleted machines always experience a consequence. As I attempt to prove in my answer, the nature of those consequences, and the "best" free space amount to avoid them, is highly configuration-specific. I suppose one could try to catalog them all, but I think that would be more confusing than helpful. – I say Reinstate Monica – 2017-10-04T15:53:30.187

Also, if you do mean to ask how specific configurations are likely to react to low disk space (e.g. with warnings, performance issues, failures, etc.) please edit your question accordingly. – I say Reinstate Monica – 2017-10-04T15:56:29.580

I would add three extra questions: 3. What are the most likely and worst case changes to disk consumption based on future growth predictions of your business, 4. cost to the business if you run out of disk space and 5. how much lead time do you need to significantly increase your disk capacity. One of my clients has 250TB of zfs raid onsite in their case they would need to know a few weeks ahead of significant changes as it takes around a day to add each larger disk into the raid array and retire the smaller one. – iheggie – 2017-10-08T05:53:41.340

12

Of course, a drive itself (HDD or SSD alike) couldn't care less about how many percents of it are in use, apart from SSDs being able to erase their free space for you beforehand. Read performance will be exactly the same, and write performance may be somewhat worse on SSD. Anyway, write performance is not that important on a nearly full drive, since there's no space to write anything.

Your OS, filesystem and applications on the other hand will expect you to have free space available at all times. 20 years ago it was typical for an application to check how much space you had on the drive before trying to save your files there. Today, application create temporary files without asking your permission, and typically crash or behave erratically when they fail to do so.

Filesystems have a similar expectation. For example, NTFS reserves a big chunk of your disk for MFT, but still shows you this space as free. When you fill your NTFS disk above 80% of its capacity, you get MFT fragmentation which has a very real impact on performance.

Furthermore, having free space does indeed help against fragmentation of regular files. Filesystems tend to avoid file fragmenation by finding the right place for each file depending on its size. On a near-fill disk they'll have fewer options, so they'll have to make poorer choices.

On Windows, you're also expected to have enough disk space for the swap file, which can grow when necessary. If it can't, you should expect your apps getting forcibly closed. Having very little swap space can indeed worsen the performance.

Even if your swap has fixed size, running completely out of system disk space can crash your system and / or make it unbootable (Windows and Linux alike), because the OS will expect to be able to write to disk during booting. So yes, hitting 90% of disk usage should make you consider your paints being on fire. Not once have I seen computers which failed to boot properly until recent downloads were removed to give the OS a little disk space.

Dmitry Grigoryev

Posted 2017-10-04T11:43:23.607

Reputation: 7 505

8

For SSDs there should be some space left because rewrite rate then increases and negatively affects write performance of the disk. The 80% full is safe value probably for all SSD disks, some latest models may work fine even with 90-95% occupied capacity.

https://www.howtogeek.com/165542/why-solid-state-drives-slow-down-as-you-fill-them-up/

Jaroslav Kucera

Posted 2017-10-04T11:43:23.607

Reputation: 1 352

1Mod Up - SSDs are very different the HDDs. Though the exact mechanism differs between drives, SSDs write [even identically placed] data to different [free] places on the disk and use subsequent garbage collection to prevent excessive wear on one spot (this is callled "wear leveling"). The fuller the disk - the less effectively it can do this. – Brad – 2017-10-04T19:31:53.917

2Also worth noting that the reason some "newer" disks work fine is that they already provision a decent amount of empty space that the user doesn't have access to (especially true of "enterprise" SSDs). This means they always have "free blocks" to write data to without the "read-erase-rewrite" cycle that slows down "full" SSDs. – Stuart Brock – 2017-10-05T11:08:57.630

1Note that all SSD's already do this to a degree, and hide it from you. This is done as part of wear leveling. Leaving more free space gives more room for wear leveling. This can be beneficial for a disk that's often written to, especially if it's a cheap TLC model of SSD. Then again, you lose some of the benefits of a cheap disk if you have to leave 20% free. Finally, new disks certainly aren't better. The first generation of SSD's were SLC disks, and had 100.000 erasure cycles. Current TLC can be as low as 5000 - that's 20 times worse. – MSalters – 2017-10-06T10:42:52.127

8

The "rules" vary depending on your requirements. And there are special cases, like, for example ZFS: "At 90% capacity, ZFS switches from performance- to space-based optimization, which has massive performance implications.". Yes, this is a design aspect of ZFS...not something derived via observation or anecdotal evidence. Obviously, this is less of an issue if your ZFS storage pool consists solely of SSDs. However, even with spinning disks, you can happily reach 99% or 100% when you deal with static storage and you don't need top-notch performance - for example, your personal all-time favorite movie collection, which never changes and where safety is priority 1.

Next, btrfs - an extreme case: when free space gets too low (a few MByte), you can hit the point of no return. No, deleting files is not an option, as you can't. There is simply not enough space to delete files. btrfs is a COW (copy-on-write) file system, and you can reach a point where you cannot modify metadata any more. At this point, you can still add additional storage to your file system (a USB thumb drive might work), then delete files from the expanded file system, then shrink the file system and remove the additional storage again). Again, this is some aspect caused by the design of the file system.

People who can give you "real (serious) data" are probably the ones which deal with "real (serious) storage". Twisty's (excellent) answer mentiones hybrid arrays (consisting of massive amounts of cheap slow spinning, lots of fast spinning disks, many SSDs...) which are operated in an enterprise environment where the major limiting factor is the speed at which the admin is able to order upgrades. Going from 16T to 35T can take 6 months...so you end up with seriously backed reports which suggest to set your alarm to 50%.

Klaws

Posted 2017-10-04T11:43:23.607

Reputation: 306

2you have clearly never taken a zfs pool to 100%, which is not something that should be done intentionally. It's a pain, you can't delete anything, you will have to truncate some files to get back write access at all, even to be able to delete anything. – camelccc – 2017-10-08T01:30:49.163

4

There are many, many factors that contribute to the result in very setup-specific amounts. So, there's no hard-and-fast number, this can only be measured as a function of those parameters. (That's probably why other users report no specific research on this specific subject made - too many variables to compile anything conclusive.)

  • Hardware

    • HDD has all its sectors allocated at all times. So it absolutely doesn't care how many of them contain current user data. (For the controller, all sectors contain some data at all times, it just reads and overwrites it as told to.)
    • SSD's controller, on the other hand, (de)allocates its sectors dynamically, akin to a file system. Which makes this job harder at higher usages. How much harder it is and how much this affects observable performance depends on:
      • The controller's performance and algorithms' quality
      • Write load
      • To a letter extent, overall load (to give the controller time for garbage collection)
      • Space overprovision (some manufacturers even let the customer choose it pre-order or change dynamically)
  • File system

    • Different file systems are designed for different loads and host processing requirements. This can be tweaked to some extent by format parameters.
    • FS write performance is a function of free space and fragmentation, read performance is a function of fragmentation only. It degrades gradually from the very beginning, so the question is where your tolerable threshold lies.
  • Load type

    • Write-heavy load emphasizes quickly finding and accessing new free blocks
    • Read-heavy load emphasizes consolidating related data so it can be read with less overhead

ivan_pozdeev

Posted 2017-10-04T11:43:23.607

Reputation: 1 468

3

One thing to consider with mechanical drives is that the throughput of the outer edge is higher than the inside. This is because there are more sectors per revolution for the larger circumference of the outside.

As the drive reaches capacity, perfomance will decrease because only slower inner sectors will be available.

For a more in depth analysis see https://superuser.com/a/643634

Wes Toleman

Posted 2017-10-04T11:43:23.607

Reputation: 201

5This is only true if no files are ever removed from the drive. In real life by the time you reach 90% capacity, you'll have a bunch of free spots scattered all over the drive. – Dmitry Grigoryev – 2017-10-05T10:25:28.040

1I don't mean to say that the hard disk controller will refrain from filling gaps but that as a drive fills more inner sectors will be used. A disk at 90% capacity will use more inner sectors than one at only 55%. Seek time has a great impact on performance so this is mainly a benefit to large contiguous files. Greater available space does however mean that there is more opportunity to store large files contiguously. – Wes Toleman – 2017-10-06T09:10:09.967

@WesToleman The harddisk controller is not responsible for deciding where things go, it just maps sector numbers to physical locations. The operating system is - notably the file system. – Thorbjørn Ravn Andersen – 2017-10-07T21:35:31.337

3

It depends on the intended usage of the drive, but in general 20% to 15% free space is a good answer for spinning disks, and 10% or more is good for SSDs.

If this is the main drive on the computer and files may be moved, then 20% free space should prevent significant slowdowns. This will allow enough open space throughout the drive for data to be moved and copied as needed. A spinning drive will work best when the free locations are nearer to the original data, while in an SSD the physical location doesn't affect daily performance. So, the spinning drive should have more free space for purely performance reasons. On the SSD, the reduced free space will reduce drive longevity, but it won't reduce performance. SSD's try to store temporary data and random download files in least-used locations so they can balance the cell usage across the entire drive; otherwise a portion of the drive will age much faster than the rest of it. Some newer SSDs may intelligently re-arrange files so the empty space moves, but older drives may not do this.

If this is a media or long-term storage drive, then 5% to 10% free should be sufficient, and 10% would be preferable if it is a spinning disk. You don't need as much free space because this drive will rarely require data to be moved, so performance isn't nearly as much of a factor. The free space is useful mainly to allow bad sectors to be discarded and replaced, and to allow files to be more contiguous.

I wouldn't push any drive past 95% capacity for more than a day unless there is a very good, clear reason.

user3685427

Posted 2017-10-04T11:43:23.607

Reputation: 141