mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-03 01:06:27 +00:00
Merge pull request #128455 from jsafrane/refactor-kcm-plugins
Refactor KCM volume plugin probe
This commit is contained in:
commit
365b457e3e
@ -270,7 +270,7 @@ func newPersistentVolumeBinderControllerDescriptor() *ControllerDescriptor {
|
|||||||
|
|
||||||
func startPersistentVolumeBinderController(ctx context.Context, controllerContext ControllerContext, controllerName string) (controller.Interface, bool, error) {
|
func startPersistentVolumeBinderController(ctx context.Context, controllerContext ControllerContext, controllerName string) (controller.Interface, bool, error) {
|
||||||
logger := klog.FromContext(ctx)
|
logger := klog.FromContext(ctx)
|
||||||
plugins, err := ProbeControllerVolumePlugins(logger, controllerContext.ComponentConfig.PersistentVolumeBinderController.VolumeConfiguration)
|
plugins, err := ProbeProvisionableRecyclableVolumePlugins(logger, controllerContext.ComponentConfig.PersistentVolumeBinderController.VolumeConfiguration)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, true, fmt.Errorf("failed to probe volume plugins when starting persistentvolume controller: %v", err)
|
return nil, true, fmt.Errorf("failed to probe volume plugins when starting persistentvolume controller: %v", err)
|
||||||
}
|
}
|
||||||
@ -307,7 +307,7 @@ func startPersistentVolumeAttachDetachController(ctx context.Context, controller
|
|||||||
csiNodeInformer := controllerContext.InformerFactory.Storage().V1().CSINodes()
|
csiNodeInformer := controllerContext.InformerFactory.Storage().V1().CSINodes()
|
||||||
csiDriverInformer := controllerContext.InformerFactory.Storage().V1().CSIDrivers()
|
csiDriverInformer := controllerContext.InformerFactory.Storage().V1().CSIDrivers()
|
||||||
|
|
||||||
plugins, err := ProbeAttachableVolumePlugins(logger)
|
plugins, err := ProbeAttachableVolumePlugins(logger, controllerContext.ComponentConfig.PersistentVolumeBinderController.VolumeConfiguration)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, true, fmt.Errorf("failed to probe volume plugins when starting attach/detach controller: %v", err)
|
return nil, true, fmt.Errorf("failed to probe volume plugins when starting attach/detach controller: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -24,14 +24,14 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"k8s.io/klog/v2"
|
"k8s.io/klog/v2"
|
||||||
|
"k8s.io/kubernetes/pkg/volume/csi"
|
||||||
|
"k8s.io/kubernetes/pkg/volume/iscsi"
|
||||||
|
|
||||||
// Volume plugins
|
// Volume plugins
|
||||||
"k8s.io/kubernetes/pkg/volume"
|
"k8s.io/kubernetes/pkg/volume"
|
||||||
"k8s.io/kubernetes/pkg/volume/csi"
|
|
||||||
"k8s.io/kubernetes/pkg/volume/fc"
|
"k8s.io/kubernetes/pkg/volume/fc"
|
||||||
"k8s.io/kubernetes/pkg/volume/flexvolume"
|
"k8s.io/kubernetes/pkg/volume/flexvolume"
|
||||||
"k8s.io/kubernetes/pkg/volume/hostpath"
|
"k8s.io/kubernetes/pkg/volume/hostpath"
|
||||||
"k8s.io/kubernetes/pkg/volume/iscsi"
|
|
||||||
"k8s.io/kubernetes/pkg/volume/nfs"
|
"k8s.io/kubernetes/pkg/volume/nfs"
|
||||||
volumeutil "k8s.io/kubernetes/pkg/volume/util"
|
volumeutil "k8s.io/kubernetes/pkg/volume/util"
|
||||||
|
|
||||||
@ -42,19 +42,11 @@ import (
|
|||||||
|
|
||||||
// ProbeAttachableVolumePlugins collects all volume plugins for the attach/
|
// ProbeAttachableVolumePlugins collects all volume plugins for the attach/
|
||||||
// detach controller.
|
// detach controller.
|
||||||
// The list of plugins is manually compiled. This code and the plugin
|
func ProbeAttachableVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration) ([]volume.VolumePlugin, error) {
|
||||||
// initialization code for kubelet really, really need a through refactor.
|
return probeControllerVolumePlugins(logger, config, func(plugin volume.VolumePlugin) bool {
|
||||||
func ProbeAttachableVolumePlugins(logger klog.Logger) ([]volume.VolumePlugin, error) {
|
_, ok := plugin.(volume.AttachableVolumePlugin)
|
||||||
var err error
|
return ok
|
||||||
allPlugins := []volume.VolumePlugin{}
|
})
|
||||||
allPlugins, err = appendAttachableLegacyProviderVolumes(logger, allPlugins, utilfeature.DefaultFeatureGate)
|
|
||||||
if err != nil {
|
|
||||||
return allPlugins, err
|
|
||||||
}
|
|
||||||
allPlugins = append(allPlugins, fc.ProbeVolumePlugins()...)
|
|
||||||
allPlugins = append(allPlugins, iscsi.ProbeVolumePlugins()...)
|
|
||||||
allPlugins = append(allPlugins, csi.ProbeVolumePlugins()...)
|
|
||||||
return allPlugins, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetDynamicPluginProber gets the probers of dynamically discoverable plugins
|
// GetDynamicPluginProber gets the probers of dynamically discoverable plugins
|
||||||
@ -66,21 +58,31 @@ func GetDynamicPluginProber(config persistentvolumeconfig.VolumeConfiguration) v
|
|||||||
|
|
||||||
// ProbeExpandableVolumePlugins returns volume plugins which are expandable
|
// ProbeExpandableVolumePlugins returns volume plugins which are expandable
|
||||||
func ProbeExpandableVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration) ([]volume.VolumePlugin, error) {
|
func ProbeExpandableVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration) ([]volume.VolumePlugin, error) {
|
||||||
var err error
|
return probeControllerVolumePlugins(logger, config, func(plugin volume.VolumePlugin) bool {
|
||||||
allPlugins := []volume.VolumePlugin{}
|
_, ok := plugin.(volume.ExpandableVolumePlugin)
|
||||||
allPlugins, err = appendExpandableLegacyProviderVolumes(logger, allPlugins, utilfeature.DefaultFeatureGate)
|
return ok
|
||||||
if err != nil {
|
})
|
||||||
return allPlugins, err
|
|
||||||
}
|
|
||||||
allPlugins = append(allPlugins, fc.ProbeVolumePlugins()...)
|
|
||||||
return allPlugins, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ProbeControllerVolumePlugins collects all persistent volume plugins into an
|
func ProbeProvisionableRecyclableVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration) ([]volume.VolumePlugin, error) {
|
||||||
// easy to use list. Only volume plugins that implement any of
|
return probeControllerVolumePlugins(logger, config, func(plugin volume.VolumePlugin) bool {
|
||||||
// provisioner/recycler/deleter interface should be returned.
|
if _, ok := plugin.(volume.ProvisionableVolumePlugin); ok {
|
||||||
func ProbeControllerVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration) ([]volume.VolumePlugin, error) {
|
return true
|
||||||
allPlugins := []volume.VolumePlugin{}
|
}
|
||||||
|
if _, ok := plugin.(volume.DeletableVolumePlugin); ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
if _, ok := plugin.(volume.RecyclableVolumePlugin); ok {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// probeControllerVolumePlugins collects all persistent volume plugins
|
||||||
|
// used by KCM controllers into an easy to use list.
|
||||||
|
func probeControllerVolumePlugins(logger klog.Logger, config persistentvolumeconfig.VolumeConfiguration, filter func(plugin volume.VolumePlugin) bool) ([]volume.VolumePlugin, error) {
|
||||||
|
var allPlugins []volume.VolumePlugin
|
||||||
|
|
||||||
// The list of plugins to probe is decided by this binary, not
|
// The list of plugins to probe is decided by this binary, not
|
||||||
// by dynamic linking or other "magic". Plugins will be analyzed and
|
// by dynamic linking or other "magic". Plugins will be analyzed and
|
||||||
@ -113,14 +115,28 @@ func ProbeControllerVolumePlugins(logger klog.Logger, config persistentvolumecon
|
|||||||
klog.FlushAndExit(klog.ExitFlushTimeout, 1)
|
klog.FlushAndExit(klog.ExitFlushTimeout, 1)
|
||||||
}
|
}
|
||||||
allPlugins = append(allPlugins, nfs.ProbeVolumePlugins(nfsConfig)...)
|
allPlugins = append(allPlugins, nfs.ProbeVolumePlugins(nfsConfig)...)
|
||||||
|
allPlugins = append(allPlugins, fc.ProbeVolumePlugins()...)
|
||||||
|
allPlugins = append(allPlugins, iscsi.ProbeVolumePlugins()...)
|
||||||
|
allPlugins = append(allPlugins, csi.ProbeVolumePlugins()...)
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
allPlugins, err = appendExpandableLegacyProviderVolumes(logger, allPlugins, utilfeature.DefaultFeatureGate)
|
allPlugins, err = appendLegacyControllerProviders(logger, allPlugins, utilfeature.DefaultFeatureGate)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return allPlugins, err
|
return allPlugins, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return allPlugins, nil
|
var filteredPlugins []volume.VolumePlugin
|
||||||
|
if filter == nil {
|
||||||
|
filteredPlugins = allPlugins
|
||||||
|
} else {
|
||||||
|
for _, plugin := range allPlugins {
|
||||||
|
if filter(plugin) {
|
||||||
|
filteredPlugins = append(filteredPlugins, plugin)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return filteredPlugins, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// AttemptToLoadRecycler tries decoding a pod from a filepath for use as a recycler for a volume.
|
// AttemptToLoadRecycler tries decoding a pod from a filepath for use as a recycler for a volume.
|
||||||
|
@ -53,7 +53,7 @@ type pluginInfo struct {
|
|||||||
pluginProbeFunction probeFn
|
pluginProbeFunction probeFn
|
||||||
}
|
}
|
||||||
|
|
||||||
func appendAttachableLegacyProviderVolumes(logger klog.Logger, allPlugins []volume.VolumePlugin, featureGate featuregate.FeatureGate) ([]volume.VolumePlugin, error) {
|
func appendLegacyControllerProviders(logger klog.Logger, allPlugins []volume.VolumePlugin, featureGate featuregate.FeatureGate) ([]volume.VolumePlugin, error) {
|
||||||
pluginMigrationStatus := make(map[string]pluginInfo)
|
pluginMigrationStatus := make(map[string]pluginInfo)
|
||||||
pluginMigrationStatus[plugins.PortworxVolumePluginName] = pluginInfo{pluginMigrationFeature: features.CSIMigrationPortworx, pluginUnregisterFeature: features.InTreePluginPortworxUnregister, pluginProbeFunction: portworx.ProbeVolumePlugins}
|
pluginMigrationStatus[plugins.PortworxVolumePluginName] = pluginInfo{pluginMigrationFeature: features.CSIMigrationPortworx, pluginUnregisterFeature: features.InTreePluginPortworxUnregister, pluginProbeFunction: portworx.ProbeVolumePlugins}
|
||||||
var err error
|
var err error
|
||||||
@ -65,11 +65,3 @@ func appendAttachableLegacyProviderVolumes(logger klog.Logger, allPlugins []volu
|
|||||||
}
|
}
|
||||||
return allPlugins, nil
|
return allPlugins, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func appendExpandableLegacyProviderVolumes(logger klog.Logger, allPlugins []volume.VolumePlugin, featureGate featuregate.FeatureGate) ([]volume.VolumePlugin, error) {
|
|
||||||
return appendLegacyProviderVolumes(logger, allPlugins, featureGate)
|
|
||||||
}
|
|
||||||
|
|
||||||
func appendLegacyProviderVolumes(logger klog.Logger, allPlugins []volume.VolumePlugin, featureGate featuregate.FeatureGate) ([]volume.VolumePlugin, error) {
|
|
||||||
return appendAttachableLegacyProviderVolumes(logger, allPlugins, featureGate)
|
|
||||||
}
|
|
||||||
|
83
cmd/kube-controller-manager/app/plugins_test.go
Normal file
83
cmd/kube-controller-manager/app/plugins_test.go
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2024 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 app
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"sort"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"k8s.io/klog/v2/ktesting"
|
||||||
|
persistentvolumeconfig "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/config"
|
||||||
|
"k8s.io/kubernetes/pkg/volume"
|
||||||
|
)
|
||||||
|
|
||||||
|
func checkPlugins(t *testing.T, got []volume.VolumePlugin, expected []string) {
|
||||||
|
pluginNames := make([]string, len(got))
|
||||||
|
for i, p := range got {
|
||||||
|
pluginNames[i] = p.GetPluginName()
|
||||||
|
}
|
||||||
|
sort.Strings(pluginNames)
|
||||||
|
sort.Strings(expected)
|
||||||
|
if !reflect.DeepEqual(pluginNames, expected) {
|
||||||
|
t.Errorf("Expected %+v, got %+v", expected, pluginNames)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestProbeAttachableVolumePlugins(t *testing.T) {
|
||||||
|
logger, _ := ktesting.NewTestContext(t)
|
||||||
|
plugins, err := ProbeAttachableVolumePlugins(logger, getConfig())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("ProbeAttachableVolumePlugins failed: %s", err)
|
||||||
|
}
|
||||||
|
checkPlugins(t, plugins, []string{"kubernetes.io/csi", "kubernetes.io/fc", "kubernetes.io/iscsi"})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestProbeExpandableVolumePlugins(t *testing.T) {
|
||||||
|
logger, _ := ktesting.NewTestContext(t)
|
||||||
|
plugins, err := ProbeExpandableVolumePlugins(logger, getConfig())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("TestProbeExpandableVolumePlugins failed: %s", err)
|
||||||
|
}
|
||||||
|
checkPlugins(t, plugins, []string{"kubernetes.io/portworx-volume"})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestProbeControllerVolumePlugins(t *testing.T) {
|
||||||
|
logger, _ := ktesting.NewTestContext(t)
|
||||||
|
plugins, err := ProbeProvisionableRecyclableVolumePlugins(logger, getConfig())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("ProbeControllerVolumePlugins failed: %s", err)
|
||||||
|
}
|
||||||
|
checkPlugins(t, plugins, []string{"kubernetes.io/host-path", "kubernetes.io/nfs", "kubernetes.io/portworx-volume"})
|
||||||
|
}
|
||||||
|
|
||||||
|
func getConfig() persistentvolumeconfig.VolumeConfiguration {
|
||||||
|
return persistentvolumeconfig.VolumeConfiguration{
|
||||||
|
EnableHostPathProvisioning: true,
|
||||||
|
EnableDynamicProvisioning: true,
|
||||||
|
PersistentVolumeRecyclerConfiguration: persistentvolumeconfig.PersistentVolumeRecyclerConfiguration{
|
||||||
|
MaximumRetry: 5,
|
||||||
|
MinimumTimeoutNFS: 30,
|
||||||
|
PodTemplateFilePathNFS: "",
|
||||||
|
IncrementTimeoutNFS: 10,
|
||||||
|
PodTemplateFilePathHostPath: "",
|
||||||
|
MinimumTimeoutHostPath: 30,
|
||||||
|
IncrementTimeoutHostPath: 10,
|
||||||
|
},
|
||||||
|
FlexVolumePluginDir: "",
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user