You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Get the ID of the Azure subscription into which you will deploy the VM image. You can display all of your subscription IDs by running Login-AzureRmAccount and then Get-AzureRmSubscription.
In the script below, replace <YOUR_SUBSCRIPTION_ID> on the top line with your subscription ID obtained above.
In the script below, replace <PUT YOUR COMPLEX PASSWORD HERE> with your complex password.
Run your modified script in this directory of the cloned azure-pipelines-image-generation repo: images\win
For future use, record the script (that sets variable values) that is output at the end of this script. You can use this in the future to set the correct variable values before running Packer.
If you need to re-run this script, delete the resource group it creates (i.e. billgvs2017image), and delete the service principal (app registration) it creates (i.e. billgvs2017sp).
$subscriptionId="<YOUR_SUBSCRIPTION_ID>"
Login-AzureRmAccount
Set-AzureRmContext-Subscription $subscriptionId$rgName=$env:UserName+"vs2017image"$location="East US"New-AzureRmResourceGroup-Name $rgName-Location $location$storageAccountName=$rgNameNew-AzureRmStorageAccount-ResourceGroupName $rgName-AccountName $storageAccountName-Location $location-SkuName "Standard_LRS"$spDisplayName=$env:UserName+"vs2017sp"$spClientSecret="<PUT YOUR COMPLEX PASSWORD HERE>"$sp=New-AzureRmADServicePrincipal-DisplayName $spDisplayName-Password (ConvertTo-SecureString$spClientSecret-AsPlainText -Force)
$spAppId=$sp.ApplicationId$spClientId=$sp.ApplicationId$spObjectId=$sp.Id
Sleep 40New-AzureRmRoleAssignment-RoleDefinitionName Contributor -ServicePrincipalName $spAppId$sub=Get-AzureRmSubscription-SubscriptionId $subscriptionId$tenantId=$sub.TenantId"","Note this variable-setting script for running Packer with these Azure resources in the future:","==============================================================================================","`$spClientId = `"$spClientId`"","`$spClientSecret = `"$spClientSecret`"","`$subscriptionId = `"$subscriptionId`"","`$tenantId = `"$tenantId`"","`$spObjectId = `"$spObjectId`"","`$location = `"$location`"","`$rgName = `"$rgName`"","`$storageAccountName = `"$storageAccountName`"",""
Use Packer to build and deploy the VM image template
Open a PowerShell console window.
Verify that Packer is in your path by typing packer --version.
Run the variable-setting script that was output by the Create required Azure resources script above.
Run the Packer command line below, which uses the variables set in the previous step. This command will take approximately 8.5 hours to complete.
Create a VM based on the template created by Packer
At the end of the output from running Packer above is a URL to the VM resource template with a read access token. It ends with .json plus a query string. Note this URL.
Create a new Network Interface with a public IP address in the Azure resource group created above. Note the Resource ID of the Network Interface (visible in its Properties tab on the Azure Portal). It begins with /subscriptions/<YOUR_SUBSCRIPTION_ID>/.
As shown below, create a VM instance from the resource template. You will be prompted to enter the resource ID of the network interface you created above.
After the VM is created, remote into it using its public IP address. You can test the installed tools or install the VSTS agent and connect it to your VSTS account.