Get up and running with PowerShell in Azure Stack

This article is a quick start to install and configure PowerShell for Azure Stack. This script provided in this article is scoped to use with Azure Active Directory(AAD) based deployments and within the cloud administrative environment only. You can also use this script for user environments, but make sure to replace the Azure Resource Manager endpoint value in the Add-AzureRMEnvironment cmdlet.

This article is a condensed version of the steps described in the Install PowerShell, Download tools, Configure PowerShell articles. To install and configure PowerShell, sign in to your Azure Stack Development Kit, or a Windows-based external client if you are connected through VPN. Next, open an elevated PowerShell ISE session and run the following script:

# Specify Azure Active Directory tenant name
$TenantName = "<mydirectory>"

# Set the module repository and the execution policy
Set-PSRepository `
  -Name "PSGallery" `
  -InstallationPolicy Trusted

Set-ExecutionPolicy RemoteSigned `

# Uninstall any existing Azure PowerShell modules. To uninstall, close all the active PowerShell sessions and run the following command:
Get-Module -ListAvailable | `
  where-Object {$_.Name -like “Azure*”} | `

# Install PowerShell for Azure Stack
Install-Module `
  -Name AzureRm.BootStrapper `

Use-AzureRmProfile `
  -Profile 2017-03-09-profile `

Install-Module `
  -Name AzureStack `
  -RequiredVersion 1.2.10 `

# Download Azure Stack tools from GitHub and import the connect module
cd \

invoke-webrequest ` `

expand-archive `
  -DestinationPath . `

cd AzureStack-Tools-master

Import-Module `

# Configure the cloud administrator’s PowerShell environment.
Add-AzureRMEnvironment `
  -Name "AzureStackAdmin" `
  -ArmEndpoint https://adminmanagement.local.azurestack.external

$TenantID = Get-AzsDirectoryTenantId `
  -AADTenantName $TenantName `
  -EnvironmentName AzureStackAdmin

# Sign-in to the administrative portal.
Login-AzureRmAccount `
  -EnvironmentName "AzureStackAdmin" `
  -TenantId $TenantID 

# Register all resource providers
foreach($s in (Get-AzureRmSubscription)) {
        Select-AzureRmSubscription -SubscriptionId $s.SubscriptionId | Out-Null
        Write-Progress $($s.SubscriptionId + " : " + $s.SubscriptionName)
Get-AzureRmResourceProvider -ListAvailable | Register-AzureRmResourceProvider -Force

Test the connectivity

Now that you’ve configured PowerShell, you can test the configuration by creating a resource group:

New-AzureRMResourceGroup -Name "ContosoVMRG" -Location Local

When the resource group is created, the cmdlet output has the Provisioning state property set to "Succeeded."

Next steps