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

  1. 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
    
  2. 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 visas CBL-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

  1. Uppdatera dina befintliga mallar för att ange OSSKU=AzureLinux. I ARM-mallar använder "OSSKU: "AzureLinux" du i avsnittet agentPoolProfile . I Bicep använder osSku: "AzureLinux" du i avsnittet agentPoolProfile . Slutligen använder "os_sku = "AzureLinux" du i default_node_pool avsnittet för Terraform. Kontrollera att din apiVersion är inställd på 2023-07-01 eller senare.
  2. 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.