Create Public Access EKS Cluster¶
本文指导快速创建 EKS 集群实验环境
- 创建单个集群,可以参考章节 create cluster from scratch
- 如果希望创建多个集群在同一个 VPC 内部,可以参考章节 create cluster in specific VPC
参考 quick-setup-cloud9 快速设置实验用 Cloud9 环境
create cluster from scratch¶
- don’t put subnets/sharedNodeSecurityGroupin yourvpcsection. eksctl will create a clean vpc for you
- don’t use privateClustersection, you could make cluster api server endpointpublicorpublic and private
- you still could put your group node in private subnet for security consideration
- recommend for most of POC environment
create eks cluster¶
- 
将在下面区域创建 EKS 集群 (prepare to create eks cluster) 
 export AWS_PAGER="" export AWS_DEFAULT_REGION=$(curl -s 169.254.169.254/latest/dynamic/instance-identity/document | jq -r '.region') export AWS_REGION=${AWS_DEFAULT_REGION} export CLUSTER_NAME=ekscluster1 export EKS_VERSION=1.26 CLUSTER_NUM=$(eksctl get cluster |wc -l) export CIDR="10.25${CLUSTER_NUM}.0.0/16"
- 
执行下面代码创建配置文件 (create eks cluster)。注意集群名称,使用的 AZ 符合你所在的区域 
 AZS=($(aws ec2 describe-availability-zones \ --query 'AvailabilityZones[].ZoneName' --output text |awk '{print $1,$2}')) export AZ0=${AZS[0]} export AZ1=${AZS[1]} cat >$$.yaml <<-'EOF' --- apiVersion: eksctl.io/v1alpha5 kind: ClusterConfig metadata: name: "${CLUSTER_NAME}" region: "${AWS_REGION}" version: "${EKS_VERSION}" availabilityZones: ["${AZ0}", "${AZ1}"] vpc: cidr: "${CIDR}" clusterEndpoints: privateAccess: true publicAccess: true cloudWatch: clusterLogging: enableTypes: ["*"] # secretsEncryption: # keyARN: ${MASTER_ARN} managedNodeGroups: - name: managed-ng minSize: 1 maxSize: 5 desiredCapacity: 2 instanceType: m5.large privateNetworking: true addons: - name: vpc-cni version: latest - name: coredns version: latest - name: kube-proxy version: latest iam: withOIDC: true EOF cat $$.yaml |envsubst '$CLUSTER_NAME $AWS_REGION $AZ0 $AZ1 $EKS_VERSION $CIDR ' > cluster-${CLUSTER_NAME}.yaml
- 
创建集群,预计需要 20 分钟 (wait about 20 mins) 
 
extra service accounts¶
iam:
  withOIDC: true
  serviceAccounts:
  - metadata:
      name: aws-load-balancer-controller
      namespace: kube-system
    wellKnownPolicies:
      awsLoadBalancerController: true
  - metadata:
      name: ebs-csi-controller-sa
      namespace: kube-system
    wellKnownPolicies:
      ebsCSIController: true
  - metadata:
      name: efs-csi-controller-sa
      namespace: kube-system
    wellKnownPolicies:
      efsCSIController: true
  - metadata:
      name: cloudwatch-agent
      namespace: amazon-cloudwatch
    attachPolicyARNs:
    - "arn:aws:iam::aws:policy/CloudWatchAgentServerPolicy"
  - metadata:
      name: fluent-bit
      namespace: amazon-cloudwatch
    attachPolicyARNs:
    - "arn:aws:iam::aws:policy/CloudWatchAgentServerPolicy"
get-newest-ami¶
- 
get newest ami id for your self-managed node group, for GPU or Graviton instance (link) 
 echo ${AWS_REGION} echo ${EKS_VERSION} export AMI=$(aws ssm get-parameter --name /aws/service/eks/optimized-ami/${EKS_VERSION}/amazon-linux-2/recommended/image_id --region ${AWS_REGION} --query "Parameter.Value" --output text) cat <<-'EOF' |envsubst '$AMI' |tee -a cluster-${CLUSTER_NAME}.yaml nodeGroups: - name: ng1 minSize: 1 maxSize: 5 desiredCapacity: 1 instanceType: m5.large ssh: enableSsm: true privateNetworking: true ami: "${AMI}" amiFamily: AmazonLinux2 overrideBootstrapCommand: | #!/bin/bash source /var/lib/cloud/scripts/eksctl/bootstrap.helper.sh /etc/eks/bootstrap.sh ${CLUSTER_NAME} --container-runtime containerd --kubelet-extra-args "--node-labels=${NODE_LABELS} --max-pods=110" EOF
- 
托管节点没有 /var/lib/cloud/scripts/eksctl/bootstrap.helper.sh脚本,导致当使用定制 ami 并且 extra args 中 NODE_LABELS 参数丢失。(refer link)
access eks cluster from web console¶
- 将实验环境对应的 TeamRole角色作为集群管理员,方便使用 web 页面查看 eks 集群
 echo ${CLUSTER_NAME} ACCOUNT_ID=$(aws sts get-caller-identity --query Account --output text) AWS_REGION=us-east-2 for i in TeamRole WSOpsRole WSParticipantRole WSAdminRole ; do eksctl create iamidentitymapping \ --cluster ${CLUSTER_NAME} \ --arn arn:aws:iam::${ACCOUNT_ID}:role/${i} \ --username cluster-admin \ --group system:masters \ --region ${AWS_REGION} done
create cluster in specific VPC¶
- get target vpc id- or create new vpc (create-standard-vpc-for-lab-in-china-region)
 
 
- or create new vpc (create-standard-vpc-for-lab-in-china-region)
- create SG (../../CLI/awscli/ec2-cmd)- or using existed cluster’s shared SG (see chapter refer)
 
 
- or using existed cluster’s shared SG (see chapter refer)
- get vpc info (eks-private-access-cluster)
- cluster yaml
 --- apiVersion: eksctl.io/v1alpha5 kind: ClusterConfig metadata: name: ekscluster2 # MODIFY cluster name region: "us-east-2" # MODIFY region version: "1.26" # MODIFY version # REPLACE THIS CODE BLOCK vpc: subnets: private: us-east-2a: id: subnet-xxxxxxxx us-east-2b: id: subnet-xxxxxxxx public: us-east-2a: id: subnet-xxxxxxxx us-east-2b: id: subnet-xxxxxxxx sharedNodeSecurityGroup: sg-xxxxxxxx # REPLACE THIS CODE BLOCK clusterEndpoints: privateAccess: true publicAccess: true cloudWatch: clusterLogging: enableTypes: ["*"] # secretsEncryption: # keyARN: ${MASTER_ARN} managedNodeGroups: - name: mng1 minSize: 1 maxSize: 5 desiredCapacity: 3 instanceType: m5.large ssh: enableSsm: true privateNetworking: true iam: withOIDC: true addons: - name: vpc-cni version: latest - name: coredns version: latest # auto discovers the latest available - name: kube-proxy version: latest