Merge pull request #129062 from carlory/automated-cherry-pick-of-#128219-upstream-release-1.31
Automated cherry pick of #128219: kubelet: Fix the volume manager didn't check the device mount state in the actual state of the world before marking the volume as detached
This commit is contained in:
		| @@ -169,6 +169,11 @@ type ActualStateOfWorld interface { | |||||||
| 	// or have a mount/unmount operation pending. | 	// or have a mount/unmount operation pending. | ||||||
| 	GetAttachedVolumes() []AttachedVolume | 	GetAttachedVolumes() []AttachedVolume | ||||||
|  |  | ||||||
|  | 	// GetAttachedVolume returns the volume that is known to be attached to the node | ||||||
|  | 	// with the given volume name. If the volume is not found, the second return value | ||||||
|  | 	// is false. | ||||||
|  | 	GetAttachedVolume(volumeName v1.UniqueVolumeName) (AttachedVolume, bool) | ||||||
|  |  | ||||||
| 	// Add the specified volume to ASW as uncertainly attached. | 	// Add the specified volume to ASW as uncertainly attached. | ||||||
| 	AddAttachUncertainReconstructedVolume(volumeName v1.UniqueVolumeName, volumeSpec *volume.Spec, nodeName types.NodeName, devicePath string) error | 	AddAttachUncertainReconstructedVolume(volumeName v1.UniqueVolumeName, volumeSpec *volume.Spec, nodeName types.NodeName, devicePath string) error | ||||||
|  |  | ||||||
| @@ -1125,6 +1130,18 @@ func (asw *actualStateOfWorld) GetAttachedVolumes() []AttachedVolume { | |||||||
| 	return allAttachedVolumes | 	return allAttachedVolumes | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (asw *actualStateOfWorld) GetAttachedVolume(volumeName v1.UniqueVolumeName) (AttachedVolume, bool) { | ||||||
|  | 	asw.RLock() | ||||||
|  | 	defer asw.RUnlock() | ||||||
|  |  | ||||||
|  | 	volumeObj, ok := asw.attachedVolumes[volumeName] | ||||||
|  | 	if !ok { | ||||||
|  | 		return AttachedVolume{}, false | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return asw.newAttachedVolume(&volumeObj), true | ||||||
|  | } | ||||||
|  |  | ||||||
| func (asw *actualStateOfWorld) GetUnmountedVolumes() []AttachedVolume { | func (asw *actualStateOfWorld) GetUnmountedVolumes() []AttachedVolume { | ||||||
| 	asw.RLock() | 	asw.RLock() | ||||||
| 	defer asw.RUnlock() | 	defer asw.RUnlock() | ||||||
|   | |||||||
| @@ -269,6 +269,11 @@ func (rc *reconciler) unmountDetachDevices() { | |||||||
| 		// Check IsOperationPending to avoid marking a volume as detached if it's in the process of mounting. | 		// Check IsOperationPending to avoid marking a volume as detached if it's in the process of mounting. | ||||||
| 		if !rc.desiredStateOfWorld.VolumeExists(attachedVolume.VolumeName, attachedVolume.SELinuxMountContext) && | 		if !rc.desiredStateOfWorld.VolumeExists(attachedVolume.VolumeName, attachedVolume.SELinuxMountContext) && | ||||||
| 			!rc.operationExecutor.IsOperationPending(attachedVolume.VolumeName, nestedpendingoperations.EmptyUniquePodName, nestedpendingoperations.EmptyNodeName) { | 			!rc.operationExecutor.IsOperationPending(attachedVolume.VolumeName, nestedpendingoperations.EmptyUniquePodName, nestedpendingoperations.EmptyNodeName) { | ||||||
|  |  | ||||||
|  | 			// Re-read the actual state of the world, maybe the volume got mounted in the meantime. | ||||||
|  | 			// This is safe, because there is no pending operation (checked above) and no new operation | ||||||
|  | 			// could start in the meantime. The only goroutine that adds new operations is this reconciler. | ||||||
|  | 			attachedVolume, _ = rc.actualStateOfWorld.GetAttachedVolume(attachedVolume.VolumeName) | ||||||
| 			if attachedVolume.DeviceMayBeMounted() { | 			if attachedVolume.DeviceMayBeMounted() { | ||||||
| 				// Volume is globally mounted to device, unmount it | 				// Volume is globally mounted to device, unmount it | ||||||
| 				klog.V(5).InfoS(attachedVolume.GenerateMsgDetailed("Starting operationExecutor.UnmountDevice", "")) | 				klog.V(5).InfoS(attachedVolume.GenerateMsgDetailed("Starting operationExecutor.UnmountDevice", "")) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot