mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	Also mark the created EBS volumes with tags, so the admin knows who/what created the volumes.
		
			
				
	
	
		
			123 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2014 The Kubernetes Authors All rights reserved.
 | 
						|
 | 
						|
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 (
 | 
						|
	// This file exists to force the desired plugin implementations to be linked.
 | 
						|
	// This should probably be part of some configuration fed into the build for a
 | 
						|
	// given binary target.
 | 
						|
 | 
						|
	"fmt"
 | 
						|
 | 
						|
	//Cloud providers
 | 
						|
	_ "k8s.io/kubernetes/pkg/cloudprovider/providers"
 | 
						|
 | 
						|
	// Volume plugins
 | 
						|
	"k8s.io/kubernetes/pkg/cloudprovider"
 | 
						|
	"k8s.io/kubernetes/pkg/cloudprovider/providers/aws"
 | 
						|
	"k8s.io/kubernetes/pkg/util/io"
 | 
						|
	"k8s.io/kubernetes/pkg/volume"
 | 
						|
	"k8s.io/kubernetes/pkg/volume/aws_ebs"
 | 
						|
	"k8s.io/kubernetes/pkg/volume/cinder"
 | 
						|
	"k8s.io/kubernetes/pkg/volume/gce_pd"
 | 
						|
	"k8s.io/kubernetes/pkg/volume/host_path"
 | 
						|
	"k8s.io/kubernetes/pkg/volume/nfs"
 | 
						|
 | 
						|
	"github.com/golang/glog"
 | 
						|
)
 | 
						|
 | 
						|
// ProbeRecyclableVolumePlugins collects all persistent volume plugins into an easy to use list.
 | 
						|
func ProbeRecyclableVolumePlugins(flags VolumeConfigFlags) []volume.VolumePlugin {
 | 
						|
	allPlugins := []volume.VolumePlugin{}
 | 
						|
 | 
						|
	// The list of plugins to probe is decided by this binary, not
 | 
						|
	// by dynamic linking or other "magic".  Plugins will be analyzed and
 | 
						|
	// initialized later.
 | 
						|
 | 
						|
	// Each plugin can make use of VolumeConfig.  The single arg to this func contains *all* enumerated
 | 
						|
	// CLI flags meant to configure volume plugins.  From that single config, create an instance of volume.VolumeConfig
 | 
						|
	// for a specific plugin and pass that instance to the plugin's ProbeVolumePlugins(config) func.
 | 
						|
 | 
						|
	// HostPath recycling is for testing and development purposes only!
 | 
						|
	hostPathConfig := volume.VolumeConfig{
 | 
						|
		RecyclerMinimumTimeout:   flags.PersistentVolumeRecyclerMinimumTimeoutHostPath,
 | 
						|
		RecyclerTimeoutIncrement: flags.PersistentVolumeRecyclerIncrementTimeoutHostPath,
 | 
						|
		RecyclerPodTemplate:      volume.NewPersistentVolumeRecyclerPodTemplate(),
 | 
						|
	}
 | 
						|
	if err := AttemptToLoadRecycler(flags.PersistentVolumeRecyclerPodTemplateFilePathHostPath, &hostPathConfig); err != nil {
 | 
						|
		glog.Fatalf("Could not create hostpath recycler pod from file %s: %+v", flags.PersistentVolumeRecyclerPodTemplateFilePathHostPath, err)
 | 
						|
	}
 | 
						|
	allPlugins = append(allPlugins, host_path.ProbeVolumePlugins(hostPathConfig)...)
 | 
						|
 | 
						|
	nfsConfig := volume.VolumeConfig{
 | 
						|
		RecyclerMinimumTimeout:   flags.PersistentVolumeRecyclerMinimumTimeoutNFS,
 | 
						|
		RecyclerTimeoutIncrement: flags.PersistentVolumeRecyclerIncrementTimeoutNFS,
 | 
						|
		RecyclerPodTemplate:      volume.NewPersistentVolumeRecyclerPodTemplate(),
 | 
						|
	}
 | 
						|
	if err := AttemptToLoadRecycler(flags.PersistentVolumeRecyclerPodTemplateFilePathNFS, &nfsConfig); err != nil {
 | 
						|
		glog.Fatalf("Could not create NFS recycler pod from file %s: %+v", flags.PersistentVolumeRecyclerPodTemplateFilePathNFS, err)
 | 
						|
	}
 | 
						|
	allPlugins = append(allPlugins, nfs.ProbeVolumePlugins(nfsConfig)...)
 | 
						|
 | 
						|
	allPlugins = append(allPlugins, aws_ebs.ProbeVolumePlugins()...)
 | 
						|
	allPlugins = append(allPlugins, gce_pd.ProbeVolumePlugins()...)
 | 
						|
	allPlugins = append(allPlugins, cinder.ProbeVolumePlugins()...)
 | 
						|
 | 
						|
	return allPlugins
 | 
						|
}
 | 
						|
 | 
						|
// NewVolumeProvisioner returns a volume provisioner to use when running in a cloud or development environment.
 | 
						|
// The beta implementation of provisioning allows 1 implied provisioner per cloud, until we allow configuration of many.
 | 
						|
// We explicitly map clouds to volume plugins here which allows us to configure many later without backwards compatibility issues.
 | 
						|
// Not all cloudproviders have provisioning capability, which is the reason for the bool in the return to tell the caller to expect one or not.
 | 
						|
func NewVolumeProvisioner(cloud cloudprovider.Interface, flags VolumeConfigFlags) (volume.ProvisionableVolumePlugin, error) {
 | 
						|
	switch {
 | 
						|
	case cloud == nil && flags.EnableHostPathProvisioning:
 | 
						|
		return getProvisionablePluginFromVolumePlugins(host_path.ProbeVolumePlugins(volume.VolumeConfig{}))
 | 
						|
	case cloud != nil && aws.ProviderName == cloud.ProviderName():
 | 
						|
		return getProvisionablePluginFromVolumePlugins(aws_ebs.ProbeVolumePlugins())
 | 
						|
		//	case cloud != nil && gce.ProviderName == cloud.ProviderName():
 | 
						|
		//		return getProvisionablePluginFromVolumePlugins(gce_pd.ProbeVolumePlugins())
 | 
						|
		//	case cloud != nil && openstack.ProviderName == cloud.ProviderName():
 | 
						|
		//		return getProvisionablePluginFromVolumePlugins(cinder.ProbeVolumePlugins())
 | 
						|
	}
 | 
						|
	return nil, nil
 | 
						|
}
 | 
						|
 | 
						|
func getProvisionablePluginFromVolumePlugins(plugins []volume.VolumePlugin) (volume.ProvisionableVolumePlugin, error) {
 | 
						|
	for _, plugin := range plugins {
 | 
						|
		if provisonablePlugin, ok := plugin.(volume.ProvisionableVolumePlugin); ok {
 | 
						|
			return provisonablePlugin, nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
	return nil, fmt.Errorf("ProvisionablePlugin expected but not found in %#v: ", plugins)
 | 
						|
}
 | 
						|
 | 
						|
// AttemptToLoadRecycler tries decoding a pod from a filepath for use as a recycler for a volume.
 | 
						|
// If successful, this method will set the recycler on the config.
 | 
						|
// If unsuccessful, an error is returned. Function is exported for reuse downstream.
 | 
						|
func AttemptToLoadRecycler(path string, config *volume.VolumeConfig) error {
 | 
						|
	if path != "" {
 | 
						|
		recyclerPod, err := io.LoadPodFromFile(path)
 | 
						|
		if err != nil {
 | 
						|
			return err
 | 
						|
		}
 | 
						|
		config.RecyclerPodTemplate = recyclerPod
 | 
						|
	}
 | 
						|
	return nil
 | 
						|
}
 |