Självstudie: Migrera noder till Azure Linux
I den här självstudien, del tre av fem, migrerar du dina befintliga noder till Azure Linux. Du kan migrera dina befintliga noder till Azure Linux med någon av följande metoder:
- Ta bort befintliga nodpooler och lägg till nya Azure Linux-nodpooler.
- Os SKU-migrering på plats.
Om du inte har några befintliga noder att migrera till Azure Linux går du vidare till nästa självstudie. I senare självstudier får du lära dig hur du aktiverar telemetri och övervakning i dina kluster och uppgraderar Azure Linux-noder.
Förutsättningar
I tidigare självstudier skapade och distribuerade du en Azure Linux Container Host för AKS-kluster. För att slutföra den här självstudien måste du lägga till en Azure Linux-nodpool i ditt befintliga kluster. Om du inte har gjort det här steget och vill följa med börjar du med Självstudie 2: Lägg till en Azure Linux-nodpool i ditt befintliga AKS-kluster.
Kommentar
När du lägger till en ny Azure Linux-nodpool måste du lägga till minst en som
--mode System
. Annars tillåter INTE AKS att du tar bort din befintliga nodpool.Du behöver den senaste versionen av Azure CLI. Kör
az --version
för att hitta versionen. Om du behöver installera eller uppgradera kan du läsa Installera Azure CLI.
Lägga till Azure Linux-nodpooler och ta bort befintliga nodpooler
Lägg till en ny Azure Linux-nodpool med kommandot
az aks nodepool add
. Det här kommandot lägger till en ny nodpool i klustret med--mode System
flaggan, vilket gör den till en systemnodpool. Systemnodpooler krävs för Azure Linux-kluster.az aks nodepool add --resource-group <resource-group-name> --cluster-name <cluster-name> --name <node-pool-name> --mode System --os-sku AzureLinux
Ta bort dina befintliga noder med kommandot
az aks nodepool delete
.az aks nodepool delete --resource-group <resource-group-name> --cluster-name <cluster-name> --name <node-pool-name>
Os SKU-migrering på plats
Nu kan du migrera dina befintliga Ubuntu-nodpooler till Azure Linux genom att ändra os-SKU:n för nodpoolen, som rullar klustret via standardprocessen för nodavbildningsuppgradering. Den här nya funktionen kräver inte att nya nodpooler skapas.
Begränsningar
Det finns flera inställningar som kan blockera begäran om OS SKU-migrering. Granska följande riktlinjer och begränsningar för att säkerställa en lyckad migrering:
- Os SKU-migreringsfunktionen är inte tillgänglig via PowerShell eller Azure Portal.
- Migreringsfunktionen för OS SKU kan inte byta namn på befintliga nodpooler.
- Ubuntu och Azure Linux är de enda SKU-migreringsmålen för Linux OS SKU som stöds.
- En Ubuntu OS SKU med
UseGPUDedicatedVHD
aktiverad kan inte utföra en OS SKU-migrering. - En Ubuntu OS SKU med CVM 20.04 aktiverat kan inte utföra en OS SKU-migrering.
- Nodpooler med Kata aktiverat kan inte utföra en OS SKU-migrering.
- Windows OS SKU-migrering stöds inte.
- OS SKU-migrering från Mariner till Azure Linux stöds, men återställning till Mariner stöds inte.
Förutsättningar
- Ett befintligt AKS-kluster med minst en Ubuntu-nodpool.
- Vi rekommenderar att du ser till att dina arbetsbelastningar konfigureras och körs på Azure Linux-containervärden innan du försöker använda OS SKU-migreringsfunktionen genom att distribuera ett Azure Linux-kluster i dev/prod och verifiera att tjänsten förblir felfri.
- Se till att migreringsfunktionen fungerar för dig i test/utveckling innan du använder processen i ett produktionskluster.
- Se till att dina poddar har tillräckligt med podduppstörningsbudget så att AKS kan flytta poddar mellan virtuella datorer under uppgraderingen.
- Du behöver Azure CLI version 2.61.0 eller senare. Kör
az --version
för att hitta versionen. Om du behöver installera eller uppgradera kan du läsa Installera Azure CLI. - Om du använder Terraform måste du ha v3.111.0 eller senare av AzureRM Terraform-modulen.
Migrera OS SKU för din Ubuntu-nodpool
Migrera OS-SKU:n för nodpoolen till Azure Linux med hjälp av
az aks nodepool update
kommandot . Det här kommandot uppdaterar OS SKU för din nodpool från Ubuntu till Azure Linux. Os SKU-ändringen utlöser en omedelbar uppgraderingsåtgärd, vilket tar flera minuter att slutföra.az aks nodepool update --resource-group <resource-group-name> --cluster-name <cluster-name> --name <node-pool-name> --os-sku AzureLinux
Kommentar
Om du får problem under OS SKU-migreringen kan du återställa till din tidigare OS SKU.
Verifiera OS SKU-migreringen
När migreringen är klar i dina testkluster bör du kontrollera följande för att säkerställa en lyckad migrering:
- Om migreringsmålet är Azure Linux kör du
kubectl get nodes -o wide
kommandot . Utdata ska visasCBL-Mariner/Linux
som operativsystemavbildning och.cm2
i slutet av kernelversionen. kubectl get pods -o wide -A
Kör kommandot för att kontrollera att alla dina poddar och daemonuppsättningar körs i den nya nodpoolen.kubectl get nodes --show-labels
Kör kommandot för att kontrollera att alla nodetiketter i den uppgraderade nodpoolen är det du förväntar dig.
Dricks
Vi rekommenderar att du övervakar tjänstens hälsotillstånd i ett par veckor innan du migrerar dina produktionskluster.
Kör OS SKU-migreringen i dina produktionskluster
- Uppdatera dina befintliga mallar för att ange
OSSKU=AzureLinux
. I ARM-mallar använder"OSSKU: "AzureLinux"
du i avsnittetagentPoolProfile
. I Bicep använderosSku: "AzureLinux"
du i avsnittetagentPoolProfile
. Slutligen använder"os_sku = "AzureLinux"
du idefault_node_pool
avsnittet för Terraform. Kontrollera att dinapiVersion
är inställd på2023-07-01
eller senare. - Distribuera om arm-, Bicep- eller Terraform-mallen för klustret för att tillämpa den nya
OSSKU
inställningen. Under den här distributionen fungerar klustret som om det tar en nodavbildningsuppgradering. Klustret ökar kapaciteten och startar sedan om dina befintliga noder en i taget till den senaste AKS-avbildningen från din nya OS SKU.
Återställning
Om du får problem under OS SKU-migreringen kan du återställa till din tidigare OS SKU. För att göra detta måste du ändra OS SKU-fältet i mallen och skicka distributionen igen, vilket utlöser en annan uppgraderingsåtgärd och återställer nodpoolen till dess tidigare OS SKU.
Kommentar
OS SKU-migrering stöder inte återställning till OS SKU Mariner.
Återställ till din tidigare OS SKU med kommandot
az aks nodepool update
. Det här kommandot uppdaterar OS SKU för din nodpool från Azure Linux tillbaka till Ubuntu.az aks nodepool update --resource-group myResourceGroup --cluster-name myAKSCluster --name mynodepool --os-sku Ubuntu
Nästa steg
I den här självstudien migrerade du befintliga noder till Azure Linux med någon av följande metoder:
- Ta bort befintliga nodpooler och lägg till nya Azure Linux-nodpooler.
- Os SKU-migrering på plats.
I nästa självstudie får du lära dig hur du aktiverar telemetri för att övervaka dina kluster.