mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-25 14:23:11 +00:00 
			
		
		
		
	agent: reduce reference count for failed mount
The kata agent adds a reference for each storage object before mount and skip mount again if the storage object is known. We need to remove the object reference if mount fails. Fixes: #5364 Signed-off-by: Feng Wang <feng.wang@databricks.com>
This commit is contained in:
		| @@ -779,16 +779,20 @@ pub async fn add_storages( | |||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         // Todo need to rollback the mounted storage if err met. |         let mount_point = match res { | ||||||
|  |             Err(e) => { | ||||||
|         if res.is_err() { |  | ||||||
|                 error!( |                 error!( | ||||||
|                     logger, |                     logger, | ||||||
|                 "add_storages failed, storage: {:?}, error: {:?} ", storage, res |                     "add_storages failed, storage: {:?}, error: {:?} ", storage, e | ||||||
|                 ); |                 ); | ||||||
|  |                 let mut sb = sandbox.lock().await; | ||||||
|  |                 sb.unset_sandbox_storage(&storage.mount_point) | ||||||
|  |                     .map_err(|e| warn!(logger, "fail to unset sandbox storage {:?}", e)) | ||||||
|  |                     .ok(); | ||||||
|  |                 return Err(e); | ||||||
|             } |             } | ||||||
|  |             Ok(m) => m, | ||||||
|         let mount_point = res?; |         }; | ||||||
|  |  | ||||||
|         if !mount_point.is_empty() { |         if !mount_point.is_empty() { | ||||||
|             mount_list.push(mount_point); |             mount_list.push(mount_point); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user