Skip to content

Commit

Permalink
KB: update the fstrim document with windows info (#59)
Browse files Browse the repository at this point in the history
Signed-off-by: Vicente Cheng <[email protected]>
Co-authored-by: Kiefer Chang <[email protected]>
Co-authored-by: Jillian <[email protected]>
  • Loading branch information
3 people authored Mar 29, 2024
1 parent fbebad6 commit ffa0c66
Showing 1 changed file with 57 additions and 8 deletions.
65 changes: 57 additions & 8 deletions kb/2024-01-30/the_potential_risk_with_fstrim.md
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
---
title: Mitigating fstrim Risk
description: The potential risk with fstrim and how to avoid it
slug: the_potential_risk_with_fstrim
title: Mitigating filesystem trim Risk
description: The potential risk with filesystem trim and how to avoid it
slug: the_potential_risk_with_filesystem_trim
authors:
- name: Vicente Cheng
title: Senior Software Engineer
url: https://github.com/Vicente-Cheng
image_url: https://github.com/Vicente-Cheng.png
tags: [harvester, rancher integration, longhorn, fstrim]
tags: [harvester, rancher integration, longhorn, filesystem trim]
hide_table_of_contents: false
---

Expand All @@ -16,20 +16,55 @@ This issue is already resolved by Longhorn v1.5.4, v1.6.1, v1.7.0 and later vers
:::


Using fstrim is a common way to release unused space in a filesystem. However, this utility is known to cause IO errors when used with Longhorn volumes that are rebuilding. For more information about the errors, see the following issues:
Filesystem trim is a common way to release unused space in a filesystem. However, this operation is known to cause IO errors when used with Longhorn volumes that are rebuilding. For more information about the errors, see the following issues:

- Harvester: [Issue 4793](https://github.com/harvester/harvester/issues/4739)
- Longhorn: [Issue 7103](https://github.com/longhorn/longhorn/issues/7103)

## Risks Associated with fstrim Usage
## Risks Associated with Filesystem Trim

A consequence of the IO errors caused by fstrim is that VMs using affected Longhorn volumes become stuck. Imagine the VM is running critical applications, then becomes unavailable. This is significant because Harvester typically uses Longhorn volumes as VM disks. The IO errors will cause VMs to flap between running and paused states until volume rebuilding is completed.
A consequence of the IO errors caused by filesystem trim is that VMs using affected Longhorn volumes become stuck. Imagine the VM is running critical applications, then becomes unavailable. This is significant because Harvester typically uses Longhorn volumes as VM disks. The IO errors will cause VMs to flap between running and paused states until volume rebuilding is completed.

Although the described system behavior does not affect data integrity, it might induce panic in some users. Consider the guest Kubernetes cluster scenario. In a stuck VM, the etcd service is unavailable. The effects of this failure cascade from the Kubernetes cluster becoming unavailable to services running on the cluster becoming unavailable.

## How to Check If Filesystem Trim Is Enabled

### Linux

In most Linux distributions, filesystem trim is enabled by default. You can check if the related service fstrim is enabled by running the following command:


```
$ systemctl status fstrim.timer
● fstrim.timer - Discard unused blocks once a week
Loaded: loaded (/lib/systemd/system/fstrim.timer; enabled; vendor preset: enabled)
Active: active (waiting) since Mon 2024-03-18 03:40:24 UTC; 1 week 1 day ago
Trigger: Mon 2024-04-01 01:00:06 UTC; 5 days left
Triggers: ● fstrim.service
Docs: man:fstrim
Mar 18 03:40:24 harvester-cluster-01-pool1-49b619f6-tpc4v systemd[1]: Started Discard unused blocks once a week.
```

When the fstrim.timer service is enabled, the system periodically runs fstrim.

### Windows

You can check if filesystem trim is enabled by running the following command:

```
C:\> fsutil behavior query DisableDeleteNotify
NTFS DisableDeleteNotify = 0 (Allows TRIM operations to be sent to the storage device)
ReFS DisableDeleteNotify = 0 (Allows TRIM operations to be sent to the storage device)
```

`DisableDeleteNotify = 0` indicates that TRIM operations are enabled. For more information, see [fsutil behavior](https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/fsutil-behavior) in the Microsoft documentation.

## Risk Mitigation

One way to mitigate the described risks is to disable fstrim in VMs. fstrim is enabled by default in many modern Linux distributions.
### Linux

One way to mitigate the described risks is to disable fstrim services in VMs. fstrim services is enabled by default in many modern Linux distributions.
You can determine if fstrim is enabled in VMs that use affected Longhorn volumes by checking the following:

- `/etc/fstab`: Some root filesystems mount with the *discard* option.
Expand Down Expand Up @@ -60,4 +95,18 @@ You can determine if fstrim is enabled in VMs that use affected Longhorn volumes
AccuracySec=1h
Persistent=true
RandomizedDelaySec=6000
```
### Windows
To mitigate the described risks, you can disable TRIM operations using the following commands:
- ReFS v2
```
C:\> fsutil behavior set DisableDeleteNotify ReFS 1
```
- NTFS and ReFS v1
```
C:\> fsutil behavior set DisableDeleteNotify 1
```

0 comments on commit ffa0c66

Please sign in to comment.