Ontwikkelomgeving configureren voor implementatiescripts in ARM-sjablonen
Artikel
Meer informatie over het maken van een ontwikkelomgeving voor het ontwikkelen en testen van implementatiescripts voor ARM-sjablonen met een installatiekopieën van een implementatiescript. U kunt een Azure-containerinstantie maken of Docker gebruiken. Beide opties worden behandeld in dit artikel.
Vereisten
Azure PowerShell-container
Als u geen Azure PowerShell-implementatiescript hebt, kunt u een hello.ps1-bestand maken met behulp van de volgende inhoud:
Wanneer u een Azure CLI-implementatiescript uitvoert, slaat een omgevingsvariabele met de naam AZ_SCRIPTS_OUTPUT_PATH de locatie van het scriptuitvoerbestand op. De omgevingsvariabele is niet beschikbaar in de container voor de ontwikkelomgeving. Zie Werken met uitvoer van CLI voor meer informatie over het werken met Azure CLI-uitvoer.
Azure PowerShell-containerinstantie gebruiken
Als u uw scripts op uw computer wilt maken, moet u een opslagaccount maken en het opslagaccount koppelen aan de containerinstantie. U kunt uw script dus uploaden naar het opslagaccount en het script uitvoeren op de containerinstantie.
Notitie
Het opslagaccount dat u maakt om uw script te testen, is niet hetzelfde opslagaccount dat door de implementatiescriptservice wordt gebruikt om het script uit te voeren. De implementatiescriptservice maakt een unieke naam als een bestandsshare voor elke uitvoering.
Een Azure PowerShell-containerinstantie maken
Met de volgende Azure Resource Manager-sjabloon (ARM-sjabloon) maakt u een containerinstantie en een bestandsshare en koppelt u de bestandsshare vervolgens aan de containerinstallatiekopieën.
De standaardwaarde voor het koppelpad is /mnt/azscripts/azscriptinput. Dit is het pad in de containerinstantie waar het is gekoppeld aan de bestandsshare.
De standaardinstallatiekopieën van de container die in de sjabloon zijn opgegeven, zijn mcr.microsoft.com/azuredeploymentscripts-powershell:az9.7. Bekijk een lijst met alle ondersteunde Azure PowerShell-versies.
De sjabloon onderbreekt de containerinstantie na 1800 seconden. U hebt 30 minuten voordat de containerinstantie de status Beëindigd krijgt en de sessie wordt beëindigd.
De sjabloon implementeren:
Azure PowerShell
$projectName = Read-Host -Prompt"Enter a project name that is used to generate resource names"$location = Read-Host -Prompt"Enter the location (i.e. centralus)"$templateFile = Read-Host -Prompt"Enter the template file path and file name"$resourceGroupName = "${projectName}rg"New-AzResourceGroup -Location$location -name$resourceGroupNameNew-AzResourceGroupDeployment -resourceGroupName$resourceGroupName -TemplateFile$templatefile -projectName$projectName
Het implementatiescript uploaden
Upload uw implementatiescript naar het opslagaccount. Hier volgt een voorbeeld van een PowerShell-script:
Azure PowerShell
$projectName = Read-Host -Prompt"Enter the same project name that you used earlier"$fileName = Read-Host -Prompt"Enter the deployment script file name with the path"$resourceGroupName = "${projectName}rg"$storageAccountName = "${projectName}store"$fileShareName = "${projectName}share"$context = (Get-AzStorageAccount -ResourceGroupName$resourceGroupName -Name$storageAccountName).Context
Set-AzStorageFileContent -Context$context -ShareName$fileShareName -Source$fileName -Force
U kunt het bestand ook uploaden met behulp van Azure Portal of de Azure CLI.
Het implementatiescript testen
Open in Azure Portal de resourcegroep waarin u de containerinstantie en het opslagaccount hebt geïmplementeerd.
Open de containergroep. De standaardnaam van de containergroep is de projectnaam die is toegevoegd aan cg. De containerinstantie heeft de status Actief .
Selecteer Containers in het resourcemenu. De naam van het containerexemplaren is de projectnaam die is toegevoegd aan de container.
Selecteer Verbinding maken en selecteer vervolgens Verbinding maken. Als u geen verbinding kunt maken met de containerinstantie, start u de containergroep opnieuw en probeert u het opnieuw.
Voer in het consolevenster de volgende opdrachten uit:
Console
cd /mnt/azscripts/azscriptinput
ls
pwsh ./hello.ps1 "John Dole"
De uitvoer is Hello John Dole.
Een Azure CLI-containerinstantie gebruiken
Als u uw scripts op uw computer wilt maken, maakt u een opslagaccount en koppelt u het opslagaccount aan de containerinstantie. Vervolgens kunt u uw script uploaden naar het opslagaccount en het script uitvoeren op de containerinstantie.
Notitie
Het opslagaccount dat u maakt om uw script te testen, is niet hetzelfde opslagaccount dat door de implementatiescriptservice wordt gebruikt om het script uit te voeren. De implementatiescriptservice maakt een unieke naam als een bestandsshare voor elke uitvoering.
Een Azure CLI-containerinstantie maken
Met de volgende ARM-sjabloon maakt u een containerinstantie en een bestandsshare en koppelt u de bestandsshare vervolgens aan de containerinstallatiekopieën:
De standaardwaarde voor het koppelpad is /mnt/azscripts/azscriptinput. Dit is het pad in de containerinstantie waar het is gekoppeld aan de bestandsshare.
De standaardinstallatiekopieën van de container die in de sjabloon zijn opgegeven, zijn mcr.microsoft.com/azure-cli:2.9.1. Bekijk een lijst met ondersteunde Azure CLI-versies.
Belangrijk
Het implementatiescript maakt gebruik van de beschikbare CLI-installatiekopieën van Microsoft Container Registry (MCR). Het duurt ongeveer één maand om een CLI-installatiekopieën te certificeren voor een implementatiescript. Gebruik niet de CLI-versies die binnen 30 dagen zijn uitgebracht. Raadpleeg de releaseopmerkingen van Azure CLI om de releasedatums voor de installatiekopieën te vinden. Als u een niet-ondersteunde versie gebruikt, worden in het foutbericht de ondersteunde versies vermeld.
De sjabloon onderbreekt de containerinstantie na 1800 seconden. U hebt 30 minuten voordat de containerinstantie de terminalstatus krijgt en de sessie wordt beëindigd.
De sjabloon implementeren:
Azure PowerShell
$projectName = Read-Host -Prompt"Enter a project name that is used to generate resource names"$location = Read-Host -Prompt"Enter the location (i.e. centralus)"$templateFile = Read-Host -Prompt"Enter the template file path and file name"$resourceGroupName = "${projectName}rg"New-AzResourceGroup -Location$location -name$resourceGroupNameNew-AzResourceGroupDeployment -resourceGroupName$resourceGroupName -TemplateFile$templatefile -projectName$projectName
Het implementatiescript uploaden
Upload uw implementatiescript naar het opslagaccount. Hier volgt een PowerShell-voorbeeld:
Azure PowerShell
$projectName = Read-Host -Prompt"Enter the same project name that you used earlier"$fileName = Read-Host -Prompt"Enter the deployment script file name with the path"$resourceGroupName = "${projectName}rg"$storageAccountName = "${projectName}store"$fileShareName = "${projectName}share"$context = (Get-AzStorageAccount -ResourceGroupName$resourceGroupName -Name$storageAccountName).Context
Set-AzStorageFileContent -Context$context -ShareName$fileShareName -Source$fileName -Force
U kunt het bestand ook uploaden met behulp van Azure Portal of de Azure CLI.
Het implementatiescript testen
Open in Azure Portal de resourcegroep waarin u de containerinstantie en het opslagaccount hebt geïmplementeerd.
Open de containergroep. De standaardnaam van de containergroep is de projectnaam die is toegevoegd aan cg. De containerinstantie wordt weergegeven in de status Actief .
Selecteer Containers in het resourcemenu. De naam van het containerexemplaren is de projectnaam die is toegevoegd aan de container.
Selecteer Verbinding maken en selecteer vervolgens Verbinding maken. Als u geen verbinding kunt maken met de containerinstantie, start u de containergroep opnieuw en probeert u het opnieuw.
Voer in het consolevenster de volgende opdrachten uit:
Console
cd /mnt/azscripts/azscriptinput
ls
./hello.sh John Dole
De uitvoer is Hello John Dole.
Docker gebruiken
U kunt een vooraf geconfigureerde Docker-containerinstallatiekopieën gebruiken als uw ontwikkelomgeving voor implementatiescripts. Zie Docker downloaden om Docker te installeren.
U moet ook het delen van bestanden configureren om de map te koppelen, die de implementatiescripts bevat in de Docker-container.
Haal de containerinstallatiekopie van het implementatiescript op de lokale computer:
In het voorbeeld wordt versie PowerShell 4.3.0 gebruikt.
Een CLI-installatiekopie ophalen uit een MCR:
command
docker pull mcr.microsoft.com/azure-cli:2.0.80
In dit voorbeeld wordt versie CLI 2.0.80 gebruikt. Implementatiescript maakt gebruik van de standaard-CLI-containerinstallatiekopieën die hier worden gevonden.
Voer de Docker-installatiekopieën lokaal uit.
command
docker run -v <host drive letter>:/<host directory name>:/data -it mcr.microsoft.com/azuredeploymentscripts-powershell:az4.3
Vervang de letter> van het hoststuurprogramma en <de hostmapnaam> door een bestaande map op het gedeelde station.< De map wordt toegewezen aan de map /data in de container. Bijvoorbeeld om D:\docker toe te wijzen:
command
docker run -v d:/docker:/data -it mcr.microsoft.com/azuredeploymentscripts-powershell:az4.3
-het betekent dat de containerinstallatiekopieën actief blijven.
Een CLI-voorbeeld:
command
docker run -v d:/docker:/data -it mcr.microsoft.com/azure-cli:2.0.80
In de volgende schermopname ziet u hoe u een PowerShell-script uitvoert, aangezien u een helloworld.ps1-bestand in het gedeelde station hebt.
Nadat het script is getest, kunt u het gebruiken als een implementatiescript in uw sjablonen.
Volgende stappen
In dit artikel hebt u geleerd hoe u implementatiescripts gebruikt. Een zelfstudie voor een implementatiescript doorlopen:
Bouw end-to-end-oplossingen in Microsoft Azure om Azure Functions te maken, web-apps te implementeren en te beheren, oplossingen te ontwikkelen die gebruikmaken van Azure Storage en meer.
De syntaxis en eigenschappen van Azure Microsoft.Resources/deploymentScripts die moeten worden gebruikt in Azure Resource Manager-sjablonen voor het implementeren van de resource. Nieuwste API-versie
Hierin wordt beschreven hoe u de TEST-toolkit voor Azure Resource Manager-sjabloon (ARM-sjabloon) uitvoert op uw sjabloon. Met de toolkit kunt u zien of u aanbevolen procedures hebt geïmplementeerd.