Merge pull request #99088 from gavinfish/storage-resize
Storage: move filesystem resize code to kubernetes/mount-utils
This commit is contained in:
		| @@ -12,6 +12,8 @@ go_library( | ||||
|         "mount_linux.go", | ||||
|         "mount_unsupported.go", | ||||
|         "mount_windows.go", | ||||
|         "resizefs_linux.go", | ||||
|         "resizefs_unsupported.go", | ||||
|     ], | ||||
|     importmap = "k8s.io/kubernetes/vendor/k8s.io/mount-utils", | ||||
|     importpath = "k8s.io/mount-utils", | ||||
|   | ||||
| @@ -441,11 +441,10 @@ func (mounter *SafeFormatAndMount) formatAndMountSensitive(source string, target | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // GetDiskFormat uses 'blkid' to see if the given disk is unformatted | ||||
| func (mounter *SafeFormatAndMount) GetDiskFormat(disk string) (string, error) { | ||||
| func getDiskFormat(exec utilexec.Interface, disk string) (string, error) { | ||||
| 	args := []string{"-p", "-s", "TYPE", "-s", "PTTYPE", "-o", "export", disk} | ||||
| 	klog.V(4).Infof("Attempting to determine if disk %q is formatted using blkid with args: (%v)", disk, args) | ||||
| 	dataOut, err := mounter.Exec.Command("blkid", args...).CombinedOutput() | ||||
| 	dataOut, err := exec.Command("blkid", args...).CombinedOutput() | ||||
| 	output := string(dataOut) | ||||
| 	klog.V(4).Infof("Output: %q", output) | ||||
|  | ||||
| @@ -494,6 +493,11 @@ func (mounter *SafeFormatAndMount) GetDiskFormat(disk string) (string, error) { | ||||
| 	return fstype, nil | ||||
| } | ||||
|  | ||||
| // GetDiskFormat uses 'blkid' to see if the given disk is unformatted | ||||
| func (mounter *SafeFormatAndMount) GetDiskFormat(disk string) (string, error) { | ||||
| 	return getDiskFormat(mounter.Exec, disk) | ||||
| } | ||||
|  | ||||
| // ListProcMounts is shared with NsEnterMounter | ||||
| func ListProcMounts(mountFilePath string) ([]MountPoint, error) { | ||||
| 	content, err := utilio.ConsistentRead(mountFilePath, maxListTries) | ||||
|   | ||||
							
								
								
									
										86
									
								
								staging/src/k8s.io/mount-utils/resizefs_linux.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								staging/src/k8s.io/mount-utils/resizefs_linux.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| // +build linux | ||||
|  | ||||
| /* | ||||
| Copyright 2021 The Kubernetes Authors. | ||||
|  | ||||
| Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| you may not use this file except in compliance with the License. | ||||
| You may obtain a copy of the License at | ||||
|  | ||||
|     http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
| Unless required by applicable law or agreed to in writing, software | ||||
| distributed under the License is distributed on an "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| */ | ||||
|  | ||||
| package mount | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	"k8s.io/klog/v2" | ||||
| 	utilexec "k8s.io/utils/exec" | ||||
| ) | ||||
|  | ||||
| // ResizeFs Provides support for resizing file systems | ||||
| type ResizeFs struct { | ||||
| 	exec utilexec.Interface | ||||
| } | ||||
|  | ||||
| // NewResizeFs returns new instance of resizer | ||||
| func NewResizeFs(exec utilexec.Interface) *ResizeFs { | ||||
| 	return &ResizeFs{exec: exec} | ||||
| } | ||||
|  | ||||
| // Resize perform resize of file system | ||||
| func (resizefs *ResizeFs) Resize(devicePath string, deviceMountPath string) (bool, error) { | ||||
| 	format, err := getDiskFormat(resizefs.exec, devicePath) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		formatErr := fmt.Errorf("ResizeFS.Resize - error checking format for device %s: %v", devicePath, err) | ||||
| 		return false, formatErr | ||||
| 	} | ||||
|  | ||||
| 	// If disk has no format, there is no need to resize the disk because mkfs.* | ||||
| 	// by default will use whole disk anyways. | ||||
| 	if format == "" { | ||||
| 		return false, nil | ||||
| 	} | ||||
|  | ||||
| 	klog.V(3).Infof("ResizeFS.Resize - Expanding mounted volume %s", devicePath) | ||||
| 	switch format { | ||||
| 	case "ext3", "ext4": | ||||
| 		return resizefs.extResize(devicePath) | ||||
| 	case "xfs": | ||||
| 		return resizefs.xfsResize(deviceMountPath) | ||||
| 	} | ||||
| 	return false, fmt.Errorf("ResizeFS.Resize - resize of format %s is not supported for device %s mounted at %s", format, devicePath, deviceMountPath) | ||||
| } | ||||
|  | ||||
| func (resizefs *ResizeFs) extResize(devicePath string) (bool, error) { | ||||
| 	output, err := resizefs.exec.Command("resize2fs", devicePath).CombinedOutput() | ||||
| 	if err == nil { | ||||
| 		klog.V(2).Infof("Device %s resized successfully", devicePath) | ||||
| 		return true, nil | ||||
| 	} | ||||
|  | ||||
| 	resizeError := fmt.Errorf("resize of device %s failed: %v. resize2fs output: %s", devicePath, err, string(output)) | ||||
| 	return false, resizeError | ||||
|  | ||||
| } | ||||
|  | ||||
| func (resizefs *ResizeFs) xfsResize(deviceMountPath string) (bool, error) { | ||||
| 	args := []string{"-d", deviceMountPath} | ||||
| 	output, err := resizefs.exec.Command("xfs_growfs", args...).CombinedOutput() | ||||
|  | ||||
| 	if err == nil { | ||||
| 		klog.V(2).Infof("Device %s resized successfully", deviceMountPath) | ||||
| 		return true, nil | ||||
| 	} | ||||
|  | ||||
| 	resizeError := fmt.Errorf("resize of device %s failed: %v. xfs_growfs output: %s", deviceMountPath, err, string(output)) | ||||
| 	return false, resizeError | ||||
| } | ||||
							
								
								
									
										40
									
								
								staging/src/k8s.io/mount-utils/resizefs_unsupported.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								staging/src/k8s.io/mount-utils/resizefs_unsupported.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| // +build !linux | ||||
|  | ||||
| /* | ||||
| Copyright 2021 The Kubernetes Authors. | ||||
|  | ||||
| Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| you may not use this file except in compliance with the License. | ||||
| You may obtain a copy of the License at | ||||
|  | ||||
|     http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
| Unless required by applicable law or agreed to in writing, software | ||||
| distributed under the License is distributed on an "AS IS" BASIS, | ||||
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| */ | ||||
|  | ||||
| package mount | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	utilexec "k8s.io/utils/exec" | ||||
| ) | ||||
|  | ||||
| // ResizeFs Provides support for resizing file systems | ||||
| type ResizeFs struct { | ||||
| 	exec utilexec.Interface | ||||
| } | ||||
|  | ||||
| // NewResizeFs returns new instance of resizer | ||||
| func NewResizeFs(exec utilexec.Interface) *ResizeFs { | ||||
| 	return &ResizeFs{exec: exec} | ||||
| } | ||||
|  | ||||
| // Resize perform resize of file system | ||||
| func (resizefs *ResizeFs) Resize(devicePath string, deviceMountPath string) (bool, error) { | ||||
| 	return false, fmt.Errorf("Resize is not supported for this build") | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot