Merge pull request #57697 from dixudx/ignore_nsnet_delete_error
Automatic merge from submit-queue (batch tested with PRs 56952, 57697). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. ignore nonexistent ns net file error when deleting container network **What this PR does / why we need it**: The pod may not get deleted completely at the first time. Such `no such file or directory` error should be ignored for retry logic. **Which issue(s) this PR fixes** *(optional, in `fixes #<issue number>(, fixes #<issue_number>, ...)` format, will close the issue(s) when PR gets merged)*: Fixes #57465 **Special notes for your reviewer**: /cc @kubernetes/sig-network-misc **Release note**: ```release-note ignore nonexistent ns net file error when deleting container network in case a retry ```
This commit is contained in:
		| @@ -273,7 +273,9 @@ func (plugin *cniNetworkPlugin) deleteFromNetwork(network *cniNetwork, podName s | ||||
| 	netConf, cniNet := network.NetworkConfig, network.CNIConfig | ||||
| 	glog.V(4).Infof("About to del CNI network %v (type=%v)", netConf.Name, netConf.Plugins[0].Network.Type) | ||||
| 	err = cniNet.DelNetworkList(netConf, rt) | ||||
| 	if err != nil { | ||||
| 	// The pod may not get deleted successfully at the first time. | ||||
| 	// Ignore "no such file or directory" error in case the network has already been deleted in previous attempts. | ||||
| 	if err != nil && !strings.Contains(err.Error(), "no such file or directory") { | ||||
| 		glog.Errorf("Error deleting network: %v", err) | ||||
| 		return err | ||||
| 	} | ||||
|   | ||||
| @@ -765,7 +765,10 @@ func (plugin *kubenetNetworkPlugin) delContainerFromNetwork(config *libcni.Netwo | ||||
| 	} | ||||
|  | ||||
| 	glog.V(3).Infof("Removing %s/%s from '%s' with CNI '%s' plugin and runtime: %+v", namespace, name, config.Network.Name, config.Network.Type, rt) | ||||
| 	if err := plugin.cniConfig.DelNetwork(config, rt); err != nil { | ||||
| 	err = plugin.cniConfig.DelNetwork(config, rt) | ||||
| 	// The pod may not get deleted successfully at the first time. | ||||
| 	// Ignore "no such file or directory" error in case the network has already been deleted in previous attempts. | ||||
| 	if err != nil && !strings.Contains(err.Error(), "no such file or directory") { | ||||
| 		return fmt.Errorf("Error removing container from network: %v", err) | ||||
| 	} | ||||
| 	return nil | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Submit Queue
					Kubernetes Submit Queue