Information för community-stödda och icke-godkända distributioner

Gäller för: ✔️ Virtuella Linux-datorer ✔️ – flexibla skalningsuppsättningar

Serviceavtalet för Azure-plattformen gäller endast för virtuella datorer som kör Linux-operativsystemet när en av de godkända distributionerna används. För dessa godkända distributioner tillhandahålls förkonfigurerade Linux-avbildningar i Azure Marketplace.

Alla andra, icke-Azure Marketplace, distributioner som körs på Azure har ett antal krav. Den här artikeln kan inte vara omfattande eftersom varje distribution skiljer sig åt. Även om du uppfyller alla kriterier nedan kan du behöva justera Linux-systemet avsevärt för att det ska köras korrekt.

Den här artikeln fokuserar på allmänna riktlinjer för att köra Linux-distributionen på Azure.

Allmän information om Linux-installation

  1. Formatet hyper-V virtuell hårddisk (VHDX) stöds inte i Azure, endast fast virtuell hårddisk. Du kan konvertera disken till VHD-format med Hyper-V Manager eller cmdleten Convert-VHD . Om du använder VirtualBox väljer du Fast storlek i stället för standardstorleken (dynamiskt allokerad) när du skapar disken.

  2. Azure stöder Virtuella datorer med Gen1 (BIOS-start) & Gen2 (UEFI-start).

  3. Den maximala tillåtna storleken för den virtuella hårddisken är 1 023 GB.

  4. När du installerar Linux-systemet rekommenderar vi att du använder standardpartitioner i stället för Logical Volume Manager (LVM), vilket är standard för många installationer. Om du använder standardpartitioner undviker du LVM-namnkonflikter med klonade virtuella datorer, särskilt om en OS-disk någonsin är ansluten till en annan identisk virtuell dator för felsökning. LVM eller RAID kan användas på datadiskar.

  5. Kernel-stöd för montering av UDF-filsystem krävs. Vid den första starten på Azure skickas etableringskonfigurationen till den virtuella Linux-datorn med hjälp av UDF-formaterade media som är anslutna till gästen. Azure Linux-agenten måste montera UDF-filsystemet för att läsa dess konfiguration och etablera den virtuella datorn.

  6. Linux-kernelversioner tidigare än 2.6.37 stöder inte NUMA på Hyper-V med större VM-storlekar. Det här problemet påverkar främst äldre distributioner med den överordnade Red Hat 2.6.32-kerneln och har åtgärdats i Red Hat Enterprise Linux (RHEL) 6.6 (kernel-2.6.32-504). System som kör anpassade kernels som är äldre än 2.6.37 eller RHEL-baserade kernels som är äldre än 2.6.32-504 måste ange startparametern numa=off på kernel-kommandoraden i grub.conf. Mer information finns i Red Hat KB 436883.

  7. Konfigurera inte en växlingspartition på OS-disken. Linux-agenten kan konfigureras för att skapa en växlingsfil på den temporära resursdisken enligt beskrivningen i följande steg.

  8. Alla virtuella hårddiskar i Azure måste ha en virtuell storlek som är justerad till 1 MB (1 024 × 1 024 byte). När du konverterar från en rådisk till en virtuell hårddisk måste du se till att diskstorleken för rådata är en multipel av 1 MB före konverteringen, enligt beskrivningen i följande steg.

  9. Använd den senaste distributionsversionen, paketen och programvaran.

  10. Ta bort användare och systemkonton, offentliga nycklar, känsliga data, onödig programvara och program.

Installera kernelmoduler utan Hyper-V

Azure körs på Hyper-V-hypervisor-programmet, så Linux kräver vissa kernelmoduler för att köras i Azure. Om du har en virtuell dator som har skapats utanför Hyper-V kanske Linux-installationsprogrammet inte innehåller drivrutinerna för Hyper-V i den ursprungliga ramdisken (initrd eller initramfs), såvida inte den virtuella datorn upptäcker att den körs i en Hyper-V-miljö. När du använder ett annat virtualiseringssystem (till exempel VirtualBox, KVM och så vidare) för att förbereda Linux-avbildningen kan du behöva återskapa initrd så att åtminstone hv_vmbus och hv_storvsc kernelmoduler är tillgängliga på den ursprungliga ramdisken. Det här kända problemet gäller system som baseras på den överordnade Red Hat-distributionen och eventuellt andra.

Mekanismen för att återskapa initrd- eller initramfs-avbildningen kan variera beroende på fördelningen. Se distributionens dokumentation eller support för korrekt procedur. Här är ett exempel på hur du återskapar initrd med hjälp mkinitrd av verktyget :

  1. Säkerhetskopiera den befintliga init:e avbildningen:

    cd /boot
    sudo cp initrd-`uname -r`.img  initrd-`uname -r`.img.bak
    
  2. initrd Återskapa med kernelmodulerna hv_vmbus och hv_storvsc :

    sudo mkinitrd --preload=hv_storvsc --preload=hv_vmbus -v -f initrd-`uname -r`.img `uname -r`
    

Ändra storlek på virtuella hårddiskar

VHD-avbildningar i Azure måste ha en virtuell storlek som är justerad till 1 MB. Vanligtvis justeras virtuella hårddiskar som skapats med Hyper-V korrekt. Om den virtuella hårddisken inte är korrekt justerad kan du få ett felmeddelande som liknar följande när du försöker skapa en avbildning från din virtuella hårddisk.

The VHD http:\//\<mystorageaccount>.blob.core.windows.net/vhds/MyLinuxVM.vhd has an unsupported virtual size of 21475270656 bytes. The size must be a whole number (in MBs).

I det här fallet ändrar du storlek på den virtuella datorn med hjälp av Antingen Hyper-V Manager-konsolen eller PowerShell-cmdleten Resize-VHD . Om du inte kör i en Windows-miljö rekommenderar vi att du använder qemu-img för att konvertera (om det behövs) och ändra storlek på den virtuella hårddisken.

Anteckning

Det finns en känd bugg i qemu-img-versioner>=2.2.1 som resulterar i en felaktigt formaterad virtuell hårddisk. Problemet har åtgärdats i QEMU 2.6. Vi rekommenderar att du använder antingen qemu-img 2.2.0 eller lägre eller 2,6 eller högre.

  1. Ändra storlek på den virtuella hårddisken direkt med hjälp av verktyg som qemu-img eller vbox-manage kan resultera i en vHD som inte kan startas. Vi rekommenderar att du först konverterar den virtuella hårddisken till en RAW-diskbild. Om vm-avbildningen skapades som en RAW-diskavbildning (standard för vissa hypervisor-program, till exempel KVM), kan du hoppa över det här steget.

    qemu-img convert -f vpc -O raw MyLinuxVM.vhd MyLinuxVM.raw
    
  2. Beräkna den nödvändiga storleken på diskbilden så att den virtuella storleken justeras till 1 MB. Följande bash shell-skript använder qemu-img info för att fastställa den virtuella storleken på diskbilden och beräknar sedan storleken till nästa 1 MB.

    rawdisk="MyLinuxVM.raw"
    vhddisk="MyLinuxVM.vhd"
    
    MB=$((1024*1024))
    size=$(qemu-img info -f raw --output json "$rawdisk" | \
    gawk 'match($0, /"virtual-size": ([0-9]+),/, val) {print val[1]}')
    
    rounded_size=$(((($size+$MB-1)/$MB)*$MB))
    
    echo "Rounded Size = $rounded_size"
    
  3. Ändra storlek på rådatadisken med hjälp av $rounded_size det som anges ovan.

    qemu-img resize MyLinuxVM.raw $rounded_size
    
  4. Konvertera nu RAW-disken tillbaka till en virtuell hårddisk med fast storlek.

    qemu-img convert -f raw -o subformat=fixed,force_size -O vpc MyLinuxVM.raw MyLinuxVM.vhd
    

    Eller ta bort force_size alternativet med qemu-versioner före 2.6.

    qemu-img convert -f raw -o subformat=fixed -O vpc MyLinuxVM.raw MyLinuxVM.vhd
    

Krav för Linux-kernel

Lis-drivrutinerna (Linux Integration Services) för Hyper-V och Azure bidrar direkt till den överordnade Linux-kerneln. Många distributioner som innehåller en ny Linux-kernelversion (till exempel 3.x) har dessa drivrutiner redan tillgängliga, eller på annat sätt tillhandahåller bakåtporterade versioner av dessa drivrutiner med sina kernels. Dessa drivrutiner uppdateras ständigt i den överordnade kerneln med nya korrigeringar och funktioner, så när det är möjligt rekommenderar vi att du kör en godkänd distribution som innehåller dessa korrigeringar och uppdateringar.

Om du kör en variant av Red Hat Enterprise Linux version 6.0 till 6.3 måste du installera de senaste LIS-drivrutinerna för Hyper-V. Från och med RHEL 6.4+ (och derivat) ingår LIS-drivrutinerna redan i kerneln och därför behövs inga ytterligare installationspaket.

Om en anpassad kernel krävs rekommenderar vi en ny kernelversion (till exempel 3.8+). För distributioner eller leverantörer som underhåller sin egen kernel måste du regelbundet backportera LIS-drivrutinerna från den överordnade kerneln till din anpassade kernel. Även om du redan kör en relativt ny kernelversion rekommenderar vi starkt att du håller reda på eventuella överordnade korrigeringar i LIS-drivrutinerna och återporterar dem efter behov. Platserna för LIS-drivrutinskällfilerna anges i MAINTAINERS-filen i Linux-kernelns källträd:

    F:    arch/x86/include/asm/mshyperv.h
    F:    arch/x86/include/uapi/asm/hyperv.h
    F:    arch/x86/kernel/cpu/mshyperv.c
    F:    drivers/hid/hid-hyperv.c
    F:    drivers/hv/
    F:    drivers/input/serio/hyperv-keyboard.c
    F:    drivers/net/hyperv/
    F:    drivers/scsi/storvsc_drv.c
    F:    drivers/video/fbdev/hyperv_fb.c
    F:    include/linux/hyperv.h
    F:    tools/hv/

Följande korrigeringar måste inkluderas i kerneln. Den här listan kan inte slutföras för alla distributioner.

Azure Linux-agenten

Azure Linux-agentenwaagent etablerar en virtuell Linux-dator i Azure. Du kan hämta den senaste versionen, filproblem eller skicka pull-begäranden på GitHub-lagringsplatsen för Linux-agenten.

  • Linux-agenten släpps under Apache 2.0-licensen. Många distributioner tillhandahåller redan RPM- eller .deb-paket för agenten, och dessa paket kan enkelt installeras och uppdateras.
  • Azure Linux-agenten kräver Python v2.6+.
  • Agenten kräver också modulen python-pyasn1. De flesta distributioner tillhandahåller den här modulen som ett separat paket som ska installeras.
  • I vissa fall kanske Azure Linux-agenten inte är kompatibel med NetworkManager. Många av RPM/deb-paketen som tillhandahålls av distributioner konfigurerar NetworkManager som en konflikt med waagent-paketet. I dessa fall avinstalleras NetworkManager när du installerar Linux-agentpaketet.
  • Azure Linux-agenten måste vara minst den version som stöds.

Anteckning

Kontrollera att modulerna "udf" och "vfat" är aktiverade. Om du inaktiverar UDF-modulen uppstår ett etableringsfel. Om du inaktiverar VFAT-modulen orsakas både etablerings- och startfel. Cloud-init >= 21.2 kan etablera virtuella datorer utan att kräva UDF om: 1) den virtuella datorn skapades med offentliga SSH-nycklar och inte lösenord och 2) inga anpassade data angavs.

Allmänna systemkrav för Linux

  1. Ändra startraden för kernel i GRUB eller GRUB2 så att följande parametrar inkluderas, så att alla konsolmeddelanden skickas till den första serieporten. Dessa meddelanden kan hjälpa Azure Support med felsökning av eventuella problem.

    GRUB_CMDLINE_LINUX="rootdelay=300 console=ttyS0 earlyprintk=ttyS0 net.ifnames=0"
    

    Vi rekommenderar också att du tar bort följande parametrar om de finns.

    rhgb quiet crashkernel=auto
    

    Grafisk och tyst start är inte användbart i en molnmiljö, där vi vill att alla loggar ska skickas till serieporten. Alternativet crashkernel kan vara kvar konfigurerat om det behövs, men observera att den här parametern minskar mängden tillgängligt minne på den virtuella datorn med minst 128 MB, vilket kan vara problematiskt för mindre VM-storlekar.

  2. När du har redigerat /etc/default/grub kör du följande kommando för att återskapa grub-konfigurationen:

    sudo grub2-mkconfig -o /boot/grub2/grub.cfg
    
  3. Lägg till Hyper-V-moduler, både initrd- och initramfs-instruktioner (Dracut).

  4. Återskapa initrd eller initramfs Initramfs

    cp /boot/initramfs-$(uname -r).img /boot/initramfs-[latest kernel version ].img.bak 
    dracut -f -v /boot/initramfs-[latest kernel version ].img  [depending on the version of grub] 
    grub-mkconfig -o /boot/grub/grub.cfg 
    grub2-mkconfig -o /boot/grub2/grub.cfg 
    

    Initrd

    mv /boot/[initrd kernel] /boot/[initrd kernel]-old 
    mkinitrd /boot/initrd.img-[initrd kernel]-generic /boot/[initrd kernel]-generic-old 
    update-initramfs -c -k [initrd kernel] 
    update-grub 
    
  5. Kontrollera att SSH-servern är installerad och konfigurerad för att starta vid start. Den här konfigurationen är vanligtvis standard.

  6. Installera Azure Linux-agenten. Azure Linux-agenten krävs för att etablera en Linux-avbildning i Azure. Många distributioner tillhandahåller agenten som ett RPM- eller .deb-paket (paketet kallas vanligtvis WALinuxAgent eller walinuxagent). Agenten kan också installeras manuellt genom att följa stegen i Linux-agentguiden.

    Installera Azure Linux-agenten, cloud-init och andra nödvändiga verktyg genom att köra följande kommando:

    Redhat/Centos

    sudo yum install -y [waagent] cloud-init cloud-utils-growpart gdisk hyperv-daemons
    

    Ubuntu/Debian

    sudo apt install walinuxagent cloud-init cloud-utils-growpart gdisk hyperv-daemons
    

    Suse

    sudo zypper install python-azure-agent cloud-init cloud-utils-growpart gdisk hyperv-daemons
    

    Aktivera sedan agenten och cloud-init för alla distributioner med hjälp av:

    sudo systemctl enable waagent.service
    sudo systemctl enable cloud-init.service
    
  7. Skapa inte växlingsutrymme på OS-disken. Azure Linux-agenten kan automatiskt konfigurera växlingsutrymme med hjälp av den lokala resursdisken som är ansluten till den virtuella datorn efter etableringen i Azure. Den lokala resursdisken är en tillfällig disk och kan tömmas när den virtuella datorn avetableras. När du har installerat Azure Linux-agenten ändrar du följande parametrar i /etc/waagent.conf efter behov.

    ResourceDisk.Format=y
    ResourceDisk.Filesystem=ext4
    ResourceDisk.MountPoint=/mnt/resource
    ResourceDisk.EnableSwap=y
    ResourceDisk.SwapSizeMB=2048    ## NOTE: Set this to your desired size.
    
  8. Konfigurera cloud-init för att hantera etableringen:

    1. Konfigurera waagent för cloud-init:
      sed -i 's/Provisioning.Agent=auto/Provisioning.Agent=cloud-init/g' /etc/waagent.conf
      sed -i 's/ResourceDisk.Format=y/ResourceDisk.Format=n/g' /etc/waagent.conf
      sed -i 's/ResourceDisk.EnableSwap=y/ResourceDisk.EnableSwap=n/g' /etc/waagent.conf
      
      Om du migrerar en specifik virtuell dator och inte vill skapa en generaliserad avbildning anger du Provisioning.Agent=disabled i konfigurationen /etc/waagent.conf .
    2. Konfigurera monteringar:
      echo "Adding mounts and disk_setup to init stage"
      sed -i '/ - mounts/d' /etc/cloud/cloud.cfg
      sed -i '/ - disk_setup/d' /etc/cloud/cloud.cfg
      sed -i '/cloud_init_modules/a\\ - mounts' /etc/cloud/cloud.cfg
      sed -i '/cloud_init_modules/a\\ - disk_setup' /etc/cloud/cloud.cfg
      
    3. Konfigurera Azure-datakälla:
      echo "Allow only Azure datasource, disable fetching network setting via IMDS"
      cat > /etc/cloud/cloud.cfg.d/91-azure_datasource.cfg <<EOF
      datasource_list: [ Azure ]
      datasource:
         Azure:
           apply_network_config: False
      EOF
      
    4. Om du har konfigurerat det tar du bort befintlig växlingsfil:
      if [[ -f /mnt/resource/swapfile ]]; then
      echo "Removing swapfile" #RHEL uses a swapfile by defaul
      swapoff /mnt/resource/swapfile
      rm /mnt/resource/swapfile -f
      fi
      
  9. Konfigurera cloud-init-loggning:

    echo "Add console log file"
    cat >> /etc/cloud/cloud.cfg.d/05_logging.cfg <<EOF
    
    # This tells cloud-init to redirect its stdout and stderr to
    # 'tee -a /var/log/cloud-init-output.log' so the user can see output
    # there without needing to look on the console.
    output: {all: '| tee -a /var/log/cloud-init-output.log'}
    EOF
    
  10. Växlingskonfiguration. Skapa inte växlingsutrymme på operativsystemdisken. Tidigare konfigurerade Azure Linux-agenten automatiskt växlingsutrymme med hjälp av den lokala resursdisk som är ansluten till den virtuella datorn när den virtuella datorn har etablerats i Azure. Men detta hanteras nu av cloud-init, du får inte använda Linux-agenten för att formatera resursdisken skapa växlingsfilen, ändra följande parametrar i /etc/waagent.conf på lämpligt sätt:

    ResourceDisk.Format=n
    ResourceDisk.EnableSwap=n
    

    Om du vill montera, formatera och skapa växling kan du antingen: 1. Skicka in detta som en cloud-init-konfiguration varje gång du skapar en virtuell dator via customdata. Detta är den rekommenderade metoden. 2. Använd ett cloud-init-direktiv som bakas in i avbildningen som gör detta varje gång den virtuella datorn skapas.

           echo 'DefaultEnvironment="CLOUD_CFG=/etc/cloud/cloud.cfg.d/00-azure-swap.cfg"' >> /etc/systemd/system.conf
           cat > /etc/cloud/cloud.cfg.d/00-azure-swap.cfg << EOF
           #cloud-config
           # Generated by Azure cloud image build
           disk_setup:
             ephemeral0:
               table_type: mbr
               layout: [66, [33, 82]]
               overwrite: True
           fs_setup:
             - device: ephemeral0.1
               filesystem: ext4
             - device: ephemeral0.2
               filesystem: swap
           mounts:
             - ["ephemeral0.1", "/mnt"]
             - ["ephemeral0.2", "none", "swap", "sw,nofail,x-systemd.requires=cloud-init.service,x-systemd.device-timeout=2", "0", "0"]
           EOF
    
         ```
    
    
  11. Avetablera.

    Varning

    Om du migrerar en specifik virtuell dator och inte vill skapa en generaliserad avbildning hoppar du över avetableringssteget. Körning av kommandot waagent -force -deprovision+user gör källdatorn oanvändbar. Det här steget är endast avsett att skapa en generaliserad avbildning.

    Kör följande kommandon för att avetablera den virtuella datorn.

    # sudo rm -f /var/log/waagent.log
    # sudo cloud-init clean
    # waagent -force -deprovision+user
    # rm -f ~/.bash_history
    # export HISTSIZE=0
    # logout
    

    Anteckning

    I Virtualbox kan du se följande fel när du har kört waagent -force -deprovision som säger [Errno 5] Input/output error. Det här felmeddelandet är inte kritiskt och kan ignoreras.

  12. Stäng av den virtuella datorn och ladda upp den virtuella hårddisken till Azure.

Nästa steg

Skapa en virtuell Linux-dator från en anpassad disk med Azure CLI.