From 33c70eeeaaf19288b16f8c4fc0f64d15d288ce52 Mon Sep 17 00:00:00 2001 From: Jiaxin Shan Date: Thu, 12 Mar 2020 16:35:53 -0700 Subject: [PATCH] Add instructions to tag resource for scale from 0 case --- cluster-autoscaler/cloudprovider/aws/README.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/cluster-autoscaler/cloudprovider/aws/README.md b/cluster-autoscaler/cloudprovider/aws/README.md index 1ad2703c3511..e5e911cb7332 100644 --- a/cluster-autoscaler/cloudprovider/aws/README.md +++ b/cluster-autoscaler/cloudprovider/aws/README.md @@ -114,6 +114,7 @@ kubectl apply -f examples/cluster-autoscaler-autodiscover.yaml From CA 0.6.1 - it is possible to scale a node group to 0 (and obviously from 0), assuming that all scale-down conditions are met. If you are using `nodeSelector` you need to tag the ASG with a node-template key `"k8s.io/cluster-autoscaler/node-template/label/"` and `"k8s.io/cluster-autoscaler/node-template/taint/"` if you are using taints. +If your pods requests resource other than `cpu` and `memory`, you need to tag ASG with key `k8s.io/cluster-autoscaler/node-template/resources/`. For example for a node label of `foo=bar` you would tag the ASG with: @@ -138,6 +139,18 @@ And for a taint of `"dedicated": "foo:NoSchedule"` you would tag the ASG with: "Key": "k8s.io/cluster-autoscaler/node-template/taint/dedicated" } ``` +If you request other resources on the node, like `vpc.amazonaws.com/PrivateIPv4Address` for windows node, `ephemeral-storage`, etc, you would tag ASG with + +```json +{ + "ResourceType": "auto-scaling-group", + "ResourceId": "foo.example.com", + "PropagateAtLaunch": true, + "Value": "2", + "Key": "k8s.io/cluster-autoscaler/node-template/resources/vpc.amazonaws.com/PrivateIPv4Address" +} +``` +> Note: This is only supported in CA 1.14.x and above If you'd like to scale node groups from 0, an `autoscaling:DescribeLaunchConfigurations` or `ec2:DescribeLaunchTemplateVersions` permission is required depending on if you made your ASG with Launch Configuration or Launch Template: