-
Notifications
You must be signed in to change notification settings - Fork 166
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: Add space-consumption-guideline
Longhorn 6592 Signed-off-by: Shuo Wu <[email protected]>
- Loading branch information
Showing
1 changed file
with
38 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
--- | ||
title: "Space consumption guideline" | ||
author: Shuo Wu | ||
draft: false | ||
date: 2023-08-25 | ||
categories: | ||
- "instruction" | ||
--- | ||
|
||
## Applicable versions | ||
|
||
All Longhorn versions, but some features are introduced in v1.4.0 or v1.5.0 | ||
|
||
## Volumes consume much more space than expected | ||
|
||
Due to the fact that Longhorn volumes can hold historic data as snapshots, the volume actual size can be much greater than the spec size. For more details, you can check [this session](../../docs/1.5.1/volumes-and-nodes/volume-size/#volume-actual-size) for a better understanding over the concept of volume size. | ||
|
||
Besides, some operations like backup, rebuilding, or expansion, will lead to a hidden system snapshot creation. Hence there may be some snapshots even if users never create a snapshot for a volume manually. | ||
|
||
To eliminate space being wasted the historic data/snapshots, we would recommend applying a recurring job like `snapshot-delete` that limits the snapshot counts of volumes. You can check [the recurring job session](../../docs/1.5.1/snapshots-and-backups/scheduling-backups-and-snapshots) and see how to work. | ||
|
||
## Filesystem used size is much smaller than volume actual size | ||
|
||
The reason for this symptom is explained in [the volume size session](../../docs/1.5.1/volumes-and-nodes/volume-size/#volume-actual-size) as well. Briefly say, a volume is a block device, which does not recognize the filesystem. In other words, deleting a file from the filesystem does not mean that the related blocks can be released by the block device. | ||
|
||
In order to ask the volume or the block device to release the blocks for removed files, you can rely on `fstrim`. [This `trim` operation](../../docs/1.5.1/volumes-and-nodes/trim-filesystem) is introduced since Longhorn v1.4.0. Please see this session for details. | ||
|
||
If you make the trim operation automatic, you can apply `filesystem-trim` recurring jobs for volumes. But notice that this operation is similar to write operations, which may be resource-consuming. Please do not trigger the trim operations for lots of volumes at the same time. | ||
|
||
## Disk exhaustion | ||
|
||
In this case, the node is probably marked as NotReady due to the disk pressure. Therefore the most critical measure is to recover the node while avoiding losing volume data. | ||
|
||
To do recover nodes and disk, we would recommend directly removing some redundant replica directories for the full disk. Here redundant replicas means that the corresponding volumes have healthy replicas in other disks. Later on Longhorn will automatically rebuild new replicas in other disks if possible. | ||
Besides, users may need to expand the existing disks or add more disks to avoid future disk exhaustion issues. | ||
|
||
Notice that the disk exhausion may be caused by replicas being unevenly scheduled. Users can check [setting Replica Auto Balance](../../docs/1.5.1/high-availability/auto-balance-replicas) for this scenario. | ||
|