Een Debian VHD voor Azure voorbereiden
Van toepassing op: ✔️ Flexibele schaalsets voor Linux-VM's ✔️
Vereisten
In deze sectie wordt ervan uitgegaan dat u al een Debian Linux-besturingssysteem hebt geïnstalleerd vanaf een .iso-bestand dat van de Debian-website naar een virtuele harde schijf is gedownload. Er bestaan meerdere hulpprogramma's om VHD-bestanden te maken; Hyper-V is slechts één voorbeeld. Zie De Hyper-V-rol installeren en een virtuele machine configureren voor instructies over het gebruik van Hyper-V.
Installatieopmerkingen
- Zie ook Algemene linux-installatieopmerkingen voor meer tips over het voorbereiden van Linux voor Azure.
- De nieuwere VHDX-indeling wordt niet ondersteund in Azure. U kunt de schijf converteren naar VHD-indeling met Hyper-V-beheer of de cmdlet convert-vhd .
- Bij het installeren van het Linux-systeem wordt aanbevolen dat u standaardpartities gebruikt in plaats van LVM (vaak de standaardinstelling voor veel installaties). Dit voorkomt conflicten met de LVM-naam met gekloonde VM's, met name als een besturingssysteemschijf ooit aan een andere VIRTUELE machine moet worden gekoppeld voor probleemoplossing. LVM of RAID kan indien gewenst worden gebruikt op gegevensschijven.
- Configureer geen wisselpartitie op de besturingssysteemschijf. De Azure Linux-agent kan worden geconfigureerd voor het maken van een wisselbestand op de tijdelijke resourceschijf. Meer informatie vindt u in de onderstaande stappen.
- Alle VHD's in Azure moeten een virtuele grootte hebben die is afgestemd op 1 MB. Wanneer u converteert van een onbewerkte schijf naar VHD, moet u ervoor zorgen dat de grootte van de onbewerkte schijf vóór de conversie een veelvoud van 1 MB is. Zie Installatieopmerkingen voor Linux voor meer informatie.
Een Debian-installatiekopieën voorbereiden voor Azure
U kunt de basisinstallatiekopieën van Azure Debian Cloud maken met de fai-cloudinstallatiekopieënbouwer.
(De volgende git-kloon- en apt-installatieopdrachten zijn opgehaald uit de Debian Cloud Images-opslagplaats) Begin met het klonen van de opslagplaats en het installeren van afhankelijkheden:
$ git clone https://salsa.debian.org/cloud-team/debian-cloud-images.git
$ sudo apt install --no-install-recommends ca-certificates debsums dosfstools \
fai-server fai-setup-storage make python3 python3-libcloud python3-marshmallow \
python3-pytest python3-yaml qemu-utils udev
$ cd ./debian-cloud-images
(Optioneel) Pas de build aan door scripts (bijvoorbeeld shellscripts) toe te voegen aan ./config_space/scripts/AZURE
.
Een voorbeeld van een script voor het aanpassen van de afbeelding is:
$ mkdir -p ./config_space/scripts/AZURE
$ cat > ./config_space/scripts/AZURE/10-custom <<EOF
#!/bin/bash
\$ROOTCMD bash -c "echo test > /usr/local/share/testing"
EOF
$ sudo chmod 755 ./config_space/scripts/AZURE/10-custom
Houd er rekening mee dat het belangrijk is om opdrachten te voorzien waarmee u de installatiekopieën $ROOTCMD
wilt aanpassen, omdat dit een alias is.chroot $target
Bouw de Azure Debian-installatiekopieën:
$ make image_[release]_azure_amd64
Hiermee wordt een handvol bestanden uitgevoerd in de huidige map, met name het image_[release]_azure_amd64.raw
afbeeldingsbestand.
Als u de onbewerkte installatiekopieën wilt converteren naar VHD voor Azure, kunt u het volgende doen:
rawdisk="image_[release]_azure_amd64.raw"
vhddisk="image_[release]_azure_amd64.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))
rounded_size_adjusted=$(($rounded_size + 512))
echo "Rounded Size Adjusted = $rounded_size_adjusted"
sudo qemu-img resize "$rawdisk" $rounded_size
qemu-img convert -f raw -o subformat=fixed,force_size -O vpc "$rawdisk" "$vhddisk"
Hiermee maakt u een VHD image_[release]_azure_amd64.vhd
met een afgeronde grootte om deze naar een Azure-schijf te kunnen kopiëren.
Notitie
In plaats van de salsa-opslagplaats te klonen en lokaal installatiekopieën te bouwen, kunnen huidige stabiele afbeeldingen worden gebouwd en gedownload van FAI.
Nadat u een stabiele Debian vhd-installatiekopieën hebt gemaakt, controleert u voordat u uploadt of de volgende pakketten zijn geïnstalleerd:
- apt-get install hyperv-daemons
- apt-get install waagent # optioneel, maar aanbevolen voor wachtwoordherstel en het gebruik van extensies
- apt-get install cloud-init
Voer vervolgens een volledige upgrade uit:
- apt-get full-upgrade
De Azure-resources moeten nu worden gemaakt voor deze installatiekopieën (deze maakt gebruik van de $rounded_size_adjusted
variabele, dus deze moet zich in hetzelfde shellproces bevinden als hierboven).
az group create -l $LOCATION -n $RG
az disk create \
-n $DISK \
-g $RG \
-l $LOCATION \
--for-upload --upload-size-bytes "$rounded_size_adjusted" \
--sku standard_lrs --hyper-v-generation V1
ACCESS=$(az disk grant-access \
-n $DISK -g $RG \
--access-level write \
--duration-in-seconds 86400 \
--query accessSas -o tsv)
azcopy copy "$vhddisk" "$ACCESS" --blob-type PageBlob
az disk revoke-access -n $DISK -g $RG
az image create \
-g $RG \
-n $IMAGE \
--os-type linux \
--source $(az disk show \
-g $RG \
-n $DISK \
--query id -o tsv)
az vm create \
-g $RG \
-n $VM \
--ssh-key-value $SSH_KEY_VALUE \
--public-ip-address-dns-name $VM \
--image $(az image show \
-g $RG \
-n $IMAGE \
--query id -o tsv)
Notitie
Als de bandbreedte van uw lokale machine naar de Azure-schijf ertoe leidt dat de upload met azcopy lang wordt verwerkt, kunt u een Azure VM-jumpbox gebruiken om het proces te versnellen. U kunt dit als volgt doen:
- Maak een tarball van de VHD op uw lokale computer:
tar -czvf ./image_buster_azure_amd64.vhd.tar.gz ./image_[release]_azure_amd64.vhd
. - Maak een Virtuele Azure Linux-machine (distributie van uw keuze). Zorg ervoor dat u deze met een groot genoeg schijf maakt om de geëxtraheerde VHD op te houden.
- Download het azcopy-hulpprogramma naar de Virtuele Linux-machine van Azure. Het kan hier worden opgehaald.
- Kopieer de tarball naar de VM:
scp ./image_buster_azure_amd64.vhd.tar.gz <vm>:~
. - Pak op de VIRTUELE machine de VHD uit (
tar -xf ./image_buster_azure_amd64.vhd.tar.gz
dit duurt even, gezien de grootte van het bestand). - Ten slotte kopieert u de VHD naar de Azure-schijf met
azcopy
(de bovenstaande opdracht).
Volgende stappen: U bent nu klaar om de virtuele harde schijf van Debian Linux te gebruiken om nieuwe virtuele machines in Azure te maken. Als dit de eerste keer is dat u het VHD-bestand uploadt naar Azure, raadpleegt u Een Virtuele Linux-machine maken vanaf een aangepaste schijf.