Skip to content

Commit

Permalink
cephfs: save space in the cluster by avoiding roundoff
Browse files Browse the repository at this point in the history
CephFS controller round off ( by util.RoundOffBytes) on the size
passed in from the provisioner at present, however this can
cause wastage of space in the cluster. The CephFS filesystem is
capable of creating volume with the exact size passed in. so no
need of Roundoff here before we reach out to the cluster

```
$ ceph fs subvolume create <vol_name> <subvol_name> [--size
<size_in_bytes>]...
```

Signed-off-by: Humble Chirammal <[email protected]>
  • Loading branch information
humblec committed Sep 1, 2021
1 parent aeebd5d commit 852df7b
Showing 1 changed file with 6 additions and 1 deletion.
7 changes: 6 additions & 1 deletion internal/cephfs/controllerserver.go
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,12 @@ func (cs *ControllerServer) CreateVolume(
defer volOptions.Destroy()

if req.GetCapacityRange() != nil {
volOptions.Size = util.RoundOffBytes(req.GetCapacityRange().GetRequiredBytes())
// we were doing round off ( by util.RoundOffBytes) to the size passed
// in from the provisioner before ceph csi v3.4.0, however this can
// cause wastage of space in the cluster. The CephFS filesystem is capable
// of creating volume with the exact size passed in. so no need of Roundoff
// here before we reach out to the cluster
volOptions.Size = req.GetCapacityRange().GetRequiredBytes()
}
// TODO need to add check for 0 volume size

Expand Down

0 comments on commit 852df7b

Please sign in to comment.