In this lab we will create our Azure Kubernetes Services (AKS) distributed compute cluster.
- Azure Account
-
Login to Azure Portal at http://portal.azure.com.
-
Open the Azure Cloud Shell and choose Bash Shell (do not choose Powershell)
-
The first time Cloud Shell is started will require you to create a storage account.
-
Once your cloud shell is started, clone the workshop repo into the cloud shell environment
git clone https://github.com/Azure/kubernetes-hackfest
Note: In the cloud shell, you are automatically logged into your Azure subscription.
-
Ensure you are using the correct Azure subscription you want to deploy AKS to.
# View subscriptions az account list
# Verify selected subscription az account show
# Set correct subscription (if needed) az account set --subscription <subscription_id> # Verify correct subscription is now set az account show
-
Create a unique identifier suffix for resources to be created in this lab.
echo "\n\n# Start AKS Hackfest Lab Params">>~/.bashrc UNIQUE_SUFFIX=$USER$RANDOM # Remove Underscores and Dashes (Not Allowed in AKS and ACR Names) UNIQUE_SUFFIX="${UNIQUE_SUFFIX//_}" UNIQUE_SUFFIX="${UNIQUE_SUFFIX//-}" # Check Unique Suffix Value (Should be No Underscores or Dashes) echo $UNIQUE_SUFFIX # Persist for Later Sessions in Case of Timeout echo export UNIQUE_SUFFIX=$UNIQUE_SUFFIX >> ~/.bashrc
_ Note this value as it will be used in the next couple labs. _
-
Create an Azure Resource Group in East US.
# Set Resource Group Name using the unique suffix RGNAME=aks-rg-$UNIQUE_SUFFIX # Persist for Later Sessions in Case of Timeout echo export RGNAME=$RGNAME >> ~/.bashrc # Set Region (Location) LOCATION=eastus # Persist for Later Sessions in Case of Timeout echo export LOCATION=eastus >> ~/.bashrc # Create Resource Group az group create -n $RGNAME -l $LOCATION
-
Create your AKS cluster in the resource group created above with 3 nodes. We will check for a recent version of kubnernetes before proceeding. We are also including the monitoring add-on for Azure Container Insights. You will use the Service Principal information from step 5.
Use Unique CLUSTERNAME
# Set AKS Cluster Name CLUSTERNAME=aks${UNIQUE_SUFFIX} # Look at AKS Cluster Name for Future Reference echo $CLUSTERNAME # Persist for Later Sessions in Case of Timeout echo export CLUSTERNAME=aks${UNIQUE_SUFFIX} >> ~/.bashrc
Get available kubernetes versions for the region. You will likely see more recent versions in your lab.
az aks get-versions -l $LOCATION --output table KubernetesVersion Upgrades ------------------- ----------------------- 1.21.2 None available 1.21.1 1.21.2 1.20.9 1.21.1, 1.21.2 1.20.7 1.20.9, 1.21.1, 1.21.2 1.19.13 1.20.7, 1.20.9 1.19.11 1.19.13, 1.20.7, 1.20.9
For this lab we'll use 1.21.1
K8SVERSION=1.21.1
The below command can take 10-20 minutes to run as it is creating the AKS cluster. Please be PATIENT and grab a coffee...
# Create AKS Cluster az aks create -n $CLUSTERNAME -g $RGNAME \ --kubernetes-version $K8SVERSION \ --enable-managed-identity \ --generate-ssh-keys -l $LOCATION \ --node-count 3 \ --no-wait
-
Verify your cluster status. The
ProvisioningState
should beSucceeded
az aks list -o table
Name Location ResourceGroup KubernetesVersion ProvisioningState Fqdn -------------- ---------- ----------------- ------------------- ------------------- ---------------------------------------------------------------- aks25415 eastus aks-rg-25415 1.21.1 Succeeded aks25415-aks-rg-25415-62afe9-3a0152d0.hcp.eastus.azmk8s.io
-
Get the Kubernetes config files for your new AKS cluster
az aks get-credentials -n $CLUSTERNAME -g $RGNAME
-
Verify you have API access to your new AKS cluster
Note: It can take 5 minutes for your nodes to appear and be in READY state. You can run
watch kubectl get nodes
to monitor status.kubectl get nodes
NAME STATUS ROLES AGE VERSION aks-nodepool1-16820300-vmss000000 Ready agent 2m11s v1.21.1 aks-nodepool1-16820300-vmss000001 Ready agent 2m15s v1.21.1 aks-nodepool1-16820300-vmss000002 Ready agent 2m12s v1.21.1
To see more details about your cluster:
kubectl cluster-info
Kubernetes control plane is running at https://aks25415-aks-rg-25415-62afe9-3a0152d0.hcp.eastus.azmk8s.io:443 CoreDNS is running at https://aks25415-aks-rg-25415-62afe9-3a0152d0.hcp.eastus.azmk8s.io:443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy Metrics-server is running at https://aks25415-aks-rg-25415-62afe9-3a0152d0.hcp.eastus.azmk8s.io:443/api/v1/namespaces/kube-system/services/https:metrics-server:/proxy
You should now have a Kubernetes cluster running with 3 nodes. You do not see the master servers for the cluster because these are managed by Microsoft. The Control Plane services which manage the Kubernetes cluster such as scheduling, API access, configuration data store and object controllers are all provided as services to the nodes.
This lab creates namespaces that reflect a representative example of an organization's environments. In this case dev, uat and prod. We will also apply the appopriate permissions, limits and resource quotas to each of the namespaces.
-
Navigate to the directory of the cloned repository
cd kubernetes-hackfest
-
Create three namespaces
# Create namespaces kubectl apply -f labs/create-aks-cluster/create-namespaces.yaml # Look at namespaces kubectl get ns
-
Assign CPU, memory and storage limits to namespaces
# Create namespace limits kubectl apply -f labs/create-aks-cluster/namespace-limitranges.yaml # Get list of namespaces and describe each kubectl get ns kubectl describe ns dev uat prod
-
Assign CPU, Memory and Storage Quotas to Namespaces
# Create namespace quotas kubectl apply -f labs/create-aks-cluster/namespace-quotas.yaml # Get list of namespaces and describe each kubectl get ns kubectl describe ns dev uat prod
-
Test out Limits and Quotas in dev Namespace
# Test Limits - Forbidden due to assignment of CPU too low kubectl run nginx-limittest --image=nginx --restart=Never --port=80 --requests='cpu=100m,memory=256Mi' -n dev # Test Limits - Pass due to automatic assignment within limits via defaults kubectl run nginx-limittest --image=nginx --restart=Never --port=80 -n dev # Check running pod and dev Namespace Allocations kubectl get po -n dev kubectl describe ns dev # Test Quotas - Forbidden due to memory quota exceeded kubectl run nginx-quotatest --image=nginx --restart=Never --port=80 --requests='cpu=500m,memory=1Gi' -n dev # Test Quotas - Pass due to memory within quota kubectl run nginx-quotatest --image=nginx --restart=Never --port=80 --requests='cpu=500m,memory=512Mi' -n dev # Check running pod and dev Namespace Allocations kubectl get po -n dev kubectl describe ns dev
-
Clean up limits, quotas, pods
kubectl delete -f labs/create-aks-cluster/namespace-limitranges.yaml kubectl delete -f labs/create-aks-cluster/namespace-quotas.yaml kubectl delete po nginx-limittest nginx-quotatest -n dev kubectl describe ns dev kubectl describe ns uat kubectl describe ns prod
-
Create namespace for our application. This will be used in subsequent labs.
kubectl create ns hackfest
- The limits and quotas of a namespace can be found via the kubectl describe ns <...> command. You will also be able to see current allocations.
- If pods are not deploying then check to make sure that CPU, Memory and Storage amounts are within the limits and do not exceed the overall quota of the namespace.