From ac03e66d3de27eae39a0fa8813b8ee858001a0a5 Mon Sep 17 00:00:00 2001 From: Peter Rifel Date: Sun, 12 Sep 2021 09:13:39 -0400 Subject: [PATCH] Recognize instance-type node label when EC2 metadata isn't available This fixes volume limits on nodes that dont have the EC2 metadata endpoint available. --- pkg/cloud/metadata.go | 8 +++++++- pkg/cloud/metadata_test.go | 6 ++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/pkg/cloud/metadata.go b/pkg/cloud/metadata.go index 995b043a59..4815103044 100644 --- a/pkg/cloud/metadata.go +++ b/pkg/cloud/metadata.go @@ -28,6 +28,7 @@ import ( "github.com/aws/aws-sdk-go/aws/ec2metadata" "github.com/aws/aws-sdk-go/aws/session" + corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/client-go/kubernetes" "k8s.io/client-go/rest" @@ -210,9 +211,14 @@ func KubernetesAPIInstanceInfo(clientset kubernetes.Interface) (*Metadata, error return nil, fmt.Errorf("did not find aws instance ID in node providerID string") } + var instanceType string + if it, ok := node.GetLabels()[corev1.LabelInstanceTypeStable]; ok { + instanceType = it + } + instanceInfo := Metadata{ InstanceID: instanceID, - InstanceType: "", // we have no way to find this, so we leave it empty + InstanceType: instanceType, Region: region, AvailabilityZone: availabilityZone, } diff --git a/pkg/cloud/metadata_test.go b/pkg/cloud/metadata_test.go index 07ebd34bae..1305559835 100644 --- a/pkg/cloud/metadata_test.go +++ b/pkg/cloud/metadata_test.go @@ -114,6 +114,9 @@ func TestNewMetadataService(t *testing.T) { APIVersion: "v1", }, ObjectMeta: metav1.ObjectMeta{ + Labels: map[string]string{ + "node.kubernetes.io/instance-type": stdInstanceType, + }, Name: nodeName, }, Spec: v1.NodeSpec{ @@ -325,6 +328,9 @@ func TestNewMetadataService(t *testing.T) { if m.GetInstanceID() != stdInstanceID { t.Errorf("NewMetadataService() failed: got wrong instance ID %v, expected %v", m.GetInstanceID(), stdInstanceID) } + if m.GetInstanceType() != stdInstanceType { + t.Errorf("GetInstanceType() failed: got %v, expected %v", m.GetInstanceType(), stdInstanceType) + } if m.GetRegion() != stdRegion { t.Errorf("NewMetadataService() failed: got wrong region %v, expected %v", m.GetRegion(), stdRegion) }