cephfs: Avoid hanging lock in volume mutex lock

This patch allows to avoid hanging mutex lock scenario when
fscrypt fails to unlock. Prevents uncessary delays

Signed-off-by: Sunnatillo <sunnat.samadov@est.tech>
This commit is contained in:
Sunnatillo 2024-07-23 15:18:10 +03:00 committed by mergify[bot]
parent c875483f8a
commit d46b7d7ff4

View File

@ -164,13 +164,8 @@ func maybeUnlockFileEncryption(
} }
log.DebugLog(ctx, "Lock successfully created for volume ID %s", volID) log.DebugLog(ctx, "Lock successfully created for volume ID %s", volID)
log.DebugLog(ctx, "cephfs: unlocking fscrypt on volume %q path %s", volID, stagingTargetPath) defer func() {
err = fscrypt.Unlock(ctx, volOptions.Encryption, stagingTargetPath, string(volID)) ret, unlockErr := ioctx.Unlock(string(volID), lockName, lockCookie)
if err != nil {
return err
}
ret, err := ioctx.Unlock(string(volID), lockName, lockCookie)
switch ret { switch ret {
case 0: case 0:
log.DebugLog(ctx, "Lock %s successfully released ", lockName) log.DebugLog(ctx, "Lock %s successfully released ", lockName)
@ -178,7 +173,14 @@ func maybeUnlockFileEncryption(
log.DebugLog(ctx, "Lock is not held by the specified %s, %s pair", lockCookie, lockName) log.DebugLog(ctx, "Lock is not held by the specified %s, %s pair", lockCookie, lockName)
default: default:
log.ErrorLog(ctx, "Failed to release following lock, this will lead to orphan lock %s: %v", log.ErrorLog(ctx, "Failed to release following lock, this will lead to orphan lock %s: %v",
lockName, err) lockName, unlockErr)
}
}()
log.DebugLog(ctx, "cephfs: unlocking fscrypt on volume %q path %s", volID, stagingTargetPath)
err = fscrypt.Unlock(ctx, volOptions.Encryption, stagingTargetPath, string(volID))
if err != nil {
return err
} }
return nil return nil