Delen via


Azure PowerShell-cmdlets uitvoeren in PowerShell-jobs

Azure PowerShell is afhankelijk van het maken van verbinding met een Azure-cloud en wachten op antwoorden. De meeste van deze cmdlets blokkeren uw PowerShell-sessie totdat ze een antwoord van de cloud krijgen. Met PowerShell-taken kunt u cmdlets op de achtergrond uitvoeren of meerdere taken tegelijk uitvoeren in Azure, vanuit één PowerShell-sessie.

Dit artikel is een kort overzicht van het uitvoeren van Azure PowerShell-cmdlets als PowerShell-taken en het controleren op voltooiing. Voor het uitvoeren van opdrachten in Azure PowerShell is het gebruik van Azure PowerShell-contexten vereist. Deze worden uitgebreid beschreven in Azure-contexten en aanmeldingsreferenties. Zie Over PowerShell-takenvoor meer informatie over PowerShell-taken.

Azure-contexten met PowerShell opdrachten

PowerShell-taken worden uitgevoerd als afzonderlijke processen zonder een gekoppelde PowerShell-sessie, zodat uw Azure-referenties met hen moeten worden gedeeld. Referenties worden doorgegeven als Azure-contextobjecten met behulp van een van de volgende methoden:

  • Automatische contextpersistentie. Contextpersistentie is standaard ingeschakeld en behoudt uw aanmeldingsgegevens voor meerdere sessies. Als contextpersistentie is ingeschakeld, wordt de huidige Azure-context doorgegeven aan het nieuwe proces:

    Enable-AzContextAutosave # Enables context autosave if not already on
    $vmadmin = Get-Credential
    
    Start-Job {
      New-AzVM -Name MyVm -Credential $Using:vmadmin
    }
    
  • Verstrek een Azure-contextobject aan een Azure PowerShell-cmdlet die een AzContext-parameter bevat:

    $context = Get-AzContext -Name 'mycontext' # Get an Azure context object
    $vmadmin = Get-Credential
    
    $job = Start-Job {
      New-AzVM -Name MyVm -AzContext $Using:context -Credential $Using:vmadmin
    }
    

    Als contextpersistentie is uitgeschakeld, is de parameter AzContext vereist.

  • Gebruik de AsJob parameter die wordt geleverd door sommige Azure PowerShell-cmdlets. Met deze schakeloptie wordt de cmdlet automatisch gestart als een PowerShell-taak met behulp van de actieve Azure-context:

    $vmadmin = Get-Credential
    $job = New-AzVM -Name MyVm -Credential $vmadmin -AsJob
    

    Als u wilt zien of een cmdlet ondersteuning biedt voor AsJob, raadpleegt u de referentiedocumentatie. De parameter AsJob vereist niet dat automatisch opslaan van context is ingeschakeld.

U kunt de status van een actieve taak controleren met de cmdlet Get-Job. Als u de uitvoer van een taak tot nu toe wilt ophalen, gebruikt u de cmdlet Receive-Job.

Als u de voortgang van een bewerking op afstand in Azure wilt controleren, gebruikt u de Get cmdlets die zijn gekoppeld aan het type resource dat door de taak wordt gewijzigd:

$vmadmin = Get-Credential
$context = Get-AzContext -Name 'mycontext'
$vmName = 'MyVm'

$job = Start-Job {
  New-AzVM -Name $Using:vmName -AzContext $Using:context -Credential $Using:vmadmin
}

Get-Job -Id $job.Id
Get-AzVM -Name $vmName

Zie ook