Skip to content

aws-load-balancer-controller

github

aws-load-balancer-controller-png-1.png

workshop

install

install-with-eksdemo-

  • https://github.com/awslabs/eksdemo/blob/main/docs/install-awslb.md
  • remove service account if existed

    echo ${CLUSTER_NAME}
    eksctl delete iamserviceaccount -c ${CLUSTER_NAME} \
        --name aws-load-balancer-controller --namespace kube-system
    

  • create

    echo ${CLUSTER_NAME}
    echo ${AWS_DEFAULT_REGION}
    
    eksdemo install aws-lb-controller -c ${CLUSTER_NAME} --namespace kube-system 
    

install-

  • https://kubernetes-sigs.github.io/aws-load-balancer-controller/latest/deploy/installation/
  • Install AWS Load Balancer Controller

    CLUSTER_NAME=ekscluster1
    AWS_REGION=us-west-2
    VPC_ID=$(aws cloudformation describe-stacks --stack-name eksctl-${CLUSTER_NAME}-cluster  --query 'Stacks[0].Outputs[?OutputKey==`VPC`].OutputValue' --output text)
    export AWS_DEFAULT_REGION=${AWS_REGION}
    export AWS_PAGER=""
    
    eksctl utils associate-iam-oidc-provider \
      --cluster ${CLUSTER_NAME} \
      --approve
    
    # curl -o iam_policy.json https://raw.githubusercontent.com/kubernetes-sigs/aws-load-balancer-controller/v2.4.1/docs/install/iam_policy.json
    git clone https://github.com/kubernetes-sigs/aws-load-balancer-controller.git
    
    # check iamserviceaccount has been create by eksctl
    aws cloudformation describe-stacks --stack-name eksctl-${CLUSTER_NAME}-addon-iamserviceaccount-kube-system-aws-load-balancer-controller 2>&1 1>/dev/null
    if [[ $? -ne 0 ]]; then
    
    if [[ ${AWS_REGION%%-*} == "cn" ]]; then 
      # aws china region
      IAM_POLICY_TEMPLATE=iam_policy_cn.json 
    else
      # aws commercial region
      IAM_POLICY_TEMPLATE=iam_policy.json 
    fi
    cp aws-load-balancer-controller/docs/install/${IAM_POLICY_TEMPLATE} .
    
    policy_name=AWSLoadBalancerControllerIAMPolicy-`date +%m%d%H%M`
    policy_arn=$(aws iam create-policy \
      --policy-name ${policy_name}  \
      --policy-document file://${IAM_POLICY_TEMPLATE} \
      --query 'Policy.Arn' \
      --output text)
    
    eksctl create iamserviceaccount \
      --cluster=${CLUSTER_NAME} \
      --namespace=kube-system \
      --name=aws-load-balancer-controller \
      --role-name=${policy_name} \
      --attach-policy-arn=${policy_arn} \
      --override-existing-serviceaccounts \
      --approve
    
    # check iamserviceaccount has been create by eksctl
    fi
    
    helm repo add eks https://aws.github.io/eks-charts
    helm repo update
    
    # following helm cmd will fail if you use 3.9.0 version
    # downgrade to helm 3.8.2
    # and another solved issue is here: [[ingress-controller-lab-issue]]
    if [[ ${AWS_REGION%%-*} == "cn" ]]; then 
      # aws china region
      helm upgrade -i aws-load-balancer-controller eks/aws-load-balancer-controller \
        -n kube-system \
        --set clusterName=${CLUSTER_NAME} \
        --set serviceAccount.create=false \
        --set serviceAccount.name=aws-load-balancer-controller \
        --set image.repository=961992271922.dkr.ecr.cn-northwest-1.amazonaws.com.cn/amazon/aws-load-balancer-controller \
        --set region=${AWS_DEFAULT_REGION} \
        --set vpcId=${VPC_ID} 
    else
      # aws commercial region
      helm install aws-load-balancer-controller eks/aws-load-balancer-controller \
        -n kube-system \
        --set clusterName=${CLUSTER_NAME} \
        --set serviceAccount.create=false \
        --set serviceAccount.name=aws-load-balancer-controller \
        --set region=${AWS_DEFAULT_REGION} \
        --set vpcId=${VPC_ID} 
    fi
    
    kubectl get deployment -n kube-system aws-load-balancer-controller
    

  • awslbc-ingress-controller-lab-issue

install-in-china-region

# using china region ecr url
helm upgrade -i aws-load-balancer-controller \
    eks/aws-load-balancer-controller \
    -n kube-system \
    --set clusterName=${CLUSTER_NAME} \
    --set serviceAccount.create=false \
    --set serviceAccount.name=aws-load-balancer-controller \
    --set image.repository=961992271922.dkr.ecr.cn-northwest-1.amazonaws.com.cn/amazon/aws-load-balancer-controller \
    # --set region=${AWS_DEFAULT_REGION} \
    # --set vpcId=${VPC_ID} 

find registry url from eks-container-image-registries-url-by-region
using parameter image.repository (refer LINK)

if you got ImagePullBackOff, could replace domain name as following

kubectl -n kube-system edit deployment aws-load-balancer-controller

# https://docs.aws.amazon.com/eks/latest/userguide/add-ons-images.html
# add `.cn` postfix for china region
REGISTRY=602401143452.dkr.ecr.us-east-1.amazonaws.com
# REGISTRY=961992271922.dkr.ecr.cn-northwest-1.amazonaws.com.cn

upgrade

Supported Kubernetes versions

  • AWS Load Balancer Controller v2.0.0~v2.1.3 requires Kubernetes 1.15+
  • AWS Load Balancer Controller v2.2.0~v2.3.1 requires Kubernetes 1.16-1.21
  • AWS Load Balancer Controller v2.4.0+ requires Kubernetes 1.19+
  • AWS Load Balancer Controller v2.5.0+ requires Kubernetes 1.22+
  • AWS Load Balancer Controller v2.6.0+ requires Kubernetes 1.22+
  • AWS Load Balancer Controller v2.7.0+ requires Kubernetes 1.22+

check version

helm list -n kube-system

in private cluster

如果节点组无法访问公网,则创建 ingress 时感觉很慢,约 5-6 分钟才能看到 alb,分析日志看到,创建 alb 过程中会访问 shieldwafv2 等服务时超时导致

blog

refer

aws-load-balancer-controller-png-2.png