mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-01-18 02:39:30 +00:00
Merge pull request #169 from Rakshith-R/backport-sparsify
rbd: do not execute rbd sparsify when volume is in use
This commit is contained in:
commit
2b5cc6c27a
@ -18,11 +18,13 @@ package rbd
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
csicommon "github.com/ceph/ceph-csi/internal/csi-common"
|
csicommon "github.com/ceph/ceph-csi/internal/csi-common"
|
||||||
rbdutil "github.com/ceph/ceph-csi/internal/rbd"
|
rbdutil "github.com/ceph/ceph-csi/internal/rbd"
|
||||||
"github.com/ceph/ceph-csi/internal/util"
|
"github.com/ceph/ceph-csi/internal/util"
|
||||||
|
"github.com/ceph/ceph-csi/internal/util/log"
|
||||||
|
|
||||||
"github.com/container-storage-interface/spec/lib/go/csi"
|
"github.com/container-storage-interface/spec/lib/go/csi"
|
||||||
rs "github.com/csi-addons/spec/lib/go/reclaimspace"
|
rs "github.com/csi-addons/spec/lib/go/reclaimspace"
|
||||||
@ -69,6 +71,13 @@ func (rscs *ReclaimSpaceControllerServer) ControllerReclaimSpace(
|
|||||||
defer rbdVol.Destroy()
|
defer rbdVol.Destroy()
|
||||||
|
|
||||||
err = rbdVol.Sparsify()
|
err = rbdVol.Sparsify()
|
||||||
|
if errors.Is(err, rbdutil.ErrImageInUse) {
|
||||||
|
// FIXME: https://github.com/csi-addons/kubernetes-csi-addons/issues/406.
|
||||||
|
// treat sparsify call as no-op if volume is in use.
|
||||||
|
log.DebugLog(ctx, fmt.Sprintf("volume with ID %q is in use, skipping sparsify operation", volumeID))
|
||||||
|
|
||||||
|
return &rs.ControllerReclaimSpaceResponse{}, nil
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// TODO: check for different error codes?
|
// TODO: check for different error codes?
|
||||||
return nil, status.Errorf(codes.Internal, "failed to sparsify volume %q: %s", rbdVol, err.Error())
|
return nil, status.Errorf(codes.Internal, "failed to sparsify volume %q: %s", rbdVol, err.Error())
|
||||||
|
@ -23,7 +23,18 @@ import (
|
|||||||
// Sparsify checks the size of the objects in the RBD image and calls
|
// Sparsify checks the size of the objects in the RBD image and calls
|
||||||
// rbd_sparify() to free zero-filled blocks and reduce the storage consumption
|
// rbd_sparify() to free zero-filled blocks and reduce the storage consumption
|
||||||
// of the image.
|
// of the image.
|
||||||
|
// This function will return ErrImageInUse if the image is in use, since
|
||||||
|
// sparsifying an image on which i/o is in progress is not optimal.
|
||||||
func (ri *rbdImage) Sparsify() error {
|
func (ri *rbdImage) Sparsify() error {
|
||||||
|
inUse, err := ri.isInUse()
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to check if image is in use: %w", err)
|
||||||
|
}
|
||||||
|
if inUse {
|
||||||
|
// if the image is in use, we should not sparsify it, return ErrImageInUse.
|
||||||
|
return ErrImageInUse
|
||||||
|
}
|
||||||
|
|
||||||
image, err := ri.open()
|
image, err := ri.open()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -63,4 +63,6 @@ var (
|
|||||||
ErrFetchingMirroringInfo = errors.New("failed to get mirroring info of image")
|
ErrFetchingMirroringInfo = errors.New("failed to get mirroring info of image")
|
||||||
// ErrResyncImageFailed is returned when the operation to resync the image fails.
|
// ErrResyncImageFailed is returned when the operation to resync the image fails.
|
||||||
ErrResyncImageFailed = errors.New("failed to resync image")
|
ErrResyncImageFailed = errors.New("failed to resync image")
|
||||||
|
// ErrImageInUse is returned when the image is in use.
|
||||||
|
ErrImageInUse = errors.New("image is in use")
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user