Skip to content

Commit

Permalink
AWS CSI driver
Browse files Browse the repository at this point in the history
  • Loading branch information
Ole Markus With committed Dec 19, 2020
1 parent cbb418c commit 0adde02
Show file tree
Hide file tree
Showing 44 changed files with 1,481 additions and 10 deletions.
11 changes: 11 additions & 0 deletions cmd/kops/create_cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ import (
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/klog/v2"
"k8s.io/kops/cmd/kops/util"
"k8s.io/kops/pkg/apis/kops"
api "k8s.io/kops/pkg/apis/kops"
"k8s.io/kops/pkg/apis/kops/registry"
"k8s.io/kops/pkg/apis/kops/validation"
Expand Down Expand Up @@ -384,6 +385,16 @@ func RunCreateCluster(ctx context.Context, f *util.Factory, out io.Writer, c *Cr
cluster := clusterResult.Cluster
instanceGroups := clusterResult.InstanceGroups

//Temporarily to run the e2e with ebs csi driver
if api.CloudProviderID(cluster.Spec.CloudProvider) == api.CloudProviderAWS {
cluster.Spec.CloudConfig = &kops.CloudConfiguration{
AWSEBSCSIDriver: &kops.AWSEBSCSIDriver{

Enabled: fi.Bool(true),
},
}
}

var masters []*api.InstanceGroup
var nodes []*api.InstanceGroup
for _, ig := range instanceGroups {
Expand Down
10 changes: 10 additions & 0 deletions k8s/crds/kops.k8s.io_clusters.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -214,6 +214,14 @@ spec:
cloudConfig:
description: CloudConfiguration defines the cloud provider configuration
properties:
awsEBSCSIDriver:
description: AWSEBSCSIDriver is the config for the AWS EBS CSI
driver
properties:
enabled:
description: Enabled enables the AWS EBS CSI driver
type: boolean
type: object
disableSecurityGroupIngress:
description: AWS cloud-config options
type: boolean
Expand Down Expand Up @@ -328,6 +336,8 @@ spec:
description: VSphereUsername is deprecated and will be removed
in a later version
type: string
required:
- awsEBSCSIDriver
type: object
cloudControllerManager:
description: CloudControllerManagerConfig is the configuration of
Expand Down
10 changes: 9 additions & 1 deletion pkg/apis/kops/componentconfig.go
Original file line number Diff line number Diff line change
Expand Up @@ -775,7 +775,7 @@ type CloudConfiguration struct {
// VShpereDatacenter is deprecated and will be removed in a later version
VSphereDatacenter *string `json:"vSphereDatacenter,omitempty"`
// VSphereResourcePool is deprecated and will be removed in a later version
VSphereResourcePool *string `json:"vSphereResourcePool,omitempty"`
VSphereResourcePool *string `json:"vSphereResot rcePool,omitempty"`
// VSphereDatastore is deprecated and will be removed in a later version
VSphereDatastore *string `json:"vSphereDatastore,omitempty"`
// VSphereCoreDNSServer is deprecated and will be removed in a later version
Expand All @@ -785,6 +785,14 @@ type CloudConfiguration struct {
SpotinstOrientation *string `json:"spotinstOrientation,omitempty"`
// Openstack cloud-config options
Openstack *OpenstackConfiguration `json:"openstack,omitempty"`
// AWSEBSCSIDriver is the config for the AWS EBS CSI driver
AWSEBSCSIDriver *AWSEBSCSIDriver `json:"awsEBSCSIDriver"`
}

// AWSEBSCSIDriver is the config for the AWS EBS CSI driver
type AWSEBSCSIDriver struct {
//Enabled enables the AWS EBS CSI driver
Enabled *bool `json:"enabled,omitempty"`
}

// NodeTerminationHandlerConfig determines the node termination handler configuration.
Expand Down
8 changes: 8 additions & 0 deletions pkg/apis/kops/v1alpha2/componentconfig.go
Original file line number Diff line number Diff line change
Expand Up @@ -784,6 +784,14 @@ type CloudConfiguration struct {
SpotinstOrientation *string `json:"spotinstOrientation,omitempty"`
// Openstack cloud-config options
Openstack *OpenstackConfiguration `json:"openstack,omitempty"`
// AWSEBSCSIDriver is the config for the AWS EBS CSI driver
AWSEBSCSIDriver *AWSEBSCSIDriver `json:"awsEBSCSIDriver"`
}

// AWSEBSCSIDriver is the config for the AWS EBS CSI driver
type AWSEBSCSIDriver struct {
//Enabled enables the AWS EBS CSI driver
Enabled *bool `json:"enabled,omitempty"`
}

// NodeTerminationHandlerConfig determines the node termination handler configuration.
Expand Down
48 changes: 48 additions & 0 deletions pkg/apis/kops/v1alpha2/zz_generated.conversion.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 26 additions & 0 deletions pkg/apis/kops/v1alpha2/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

16 changes: 16 additions & 0 deletions pkg/apis/kops/validation/aws.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,9 +38,25 @@ func awsValidateCluster(c *kops.Cluster) field.ErrorList {
}
}

allErrs = append(allErrs, awsValidateExternalCloudControllerManager(c.Spec)...)

return allErrs
}

func awsValidateExternalCloudControllerManager(c kops.ClusterSpec) (allErrs field.ErrorList) {

if c.ExternalCloudControllerManager != nil {
if c.KubeControllerManager == nil || c.KubeControllerManager.ExternalCloudVolumePlugin != "aws" {
if c.CloudConfig == nil || c.CloudConfig.AWSEBSCSIDriver == nil || !fi.BoolValue(c.CloudConfig.AWSEBSCSIDriver.Enabled) {
allErrs = append(allErrs, field.Forbidden(field.NewPath("spec", "externalCloudControllerManager"),
"AWS external CCM cannot be used without enabling spec.cloudConfig.AWSEBSCSIDriver or setting spec.kubeControllerManaager.externalCloudVolumePlugin set to `aws`"))
}
}
}
return allErrs

}

func awsValidateInstanceGroup(ig *kops.InstanceGroup, cloud awsup.AWSCloud) field.ErrorList {
allErrs := field.ErrorList{}

Expand Down
37 changes: 37 additions & 0 deletions pkg/apis/kops/validation/aws_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,43 @@ import (
"k8s.io/kops/pkg/apis/kops"
)

func TestAWSValidateExternalCloudConfig(t *testing.T) {
grid := []struct {
Input kops.ClusterSpec
ExpectedErrors []string
}{
{
Input: kops.ClusterSpec{
ExternalCloudControllerManager: &kops.CloudControllerManagerConfig{},
},
ExpectedErrors: []string{"Forbidden::spec.externalCloudControllerManager"},
},
{
Input: kops.ClusterSpec{
ExternalCloudControllerManager: &kops.CloudControllerManagerConfig{},
CloudConfig: &kops.CloudConfiguration{
AWSEBSCSIDriver: &kops.AWSEBSCSIDriver{
Enabled: fi.Bool(true),
},
},
},
},
{
Input: kops.ClusterSpec{
ExternalCloudControllerManager: &kops.CloudControllerManagerConfig{},
KubeControllerManager: &kops.KubeControllerManagerConfig{
ExternalCloudVolumePlugin: "aws",
},
},
},
}
for _, g := range grid {
errs := awsValidateExternalCloudControllerManager(g.Input)

testErrors(t, g.Input, errs, g.ExpectedErrors)
}
}

func TestValidateInstanceGroupSpec(t *testing.T) {
grid := []struct {
Input kops.InstanceGroupSpec
Expand Down
26 changes: 26 additions & 0 deletions pkg/apis/kops/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 0 additions & 8 deletions pkg/model/components/kubecontrollermanager.go
Original file line number Diff line number Diff line change
Expand Up @@ -98,14 +98,6 @@ func (b *KubeControllerManagerOptionsBuilder) BuildOptions(o interface{}) error

if clusterSpec.ExternalCloudControllerManager != nil {
kcm.CloudProvider = "external"

// External cloud provider disables KCM volume controllers, so
// most users would want to either install CSI or pass
// --external-cloud-volume-plugin to the KCM, which runs the
// KCM volume controllers.
if kcm.ExternalCloudVolumePlugin == "" {
klog.Infof("An external cloud controller manager is configured, but ExternalCloudVolumePlugin is not configured for the KCM. This means a CSI plugin must be installed by the user or else volume management might not work.")
}
}

kcm.LogLevel = 2
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_0.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_1.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_2.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_3.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_4.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
1 change: 1 addition & 0 deletions pkg/model/tests/data/bootstrapscript_5.txt
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ ensure-install-dir

cat > conf/cluster_spec.yaml << '__EOF_CLUSTER_SPEC'
cloudConfig:
awsEBSCSIDriver: null
nodeTags: something
containerRuntime: docker
containerd:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ spec:
authorization:
rbac: {}
channel: stable
cloudConfig:
awsEBSCSIDriver:
enabled: true
cloudProvider: aws
configBase: memfs://tests/complex.example.com
containerRuntime: docker
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ spec:
rbac: {}
channel: stable
cloudConfig:
awsEBSCSIDriver: null
gceServiceAccount: [email protected]
cloudProvider: gce
configBase: memfs://tests/gce.example.com
Expand Down
Loading

0 comments on commit 0adde02

Please sign in to comment.