Примечание.
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
Azure PowerShell зависит от подключения к Azure облаку и ожиданию ответов, поэтому большинство этих командлетов блокируют сеанс PowerShell, пока не получат ответ из облака. Задания PowerShell позволяют выполнять командлеты в фоновом режиме или выполнять несколько задач в Azure одновременно из одного сеанса PowerShell.
В этой статье представлен краткий обзор выполнения командлетов Azure PowerShell в качестве заданий PowerShell и проверки их завершения. Выполнение команд в Azure PowerShell требует использования контекстов "Azure PowerShell", которые подробно рассматриваются в контекстах Azure и учетных данных. Дополнительные сведения о заданиях PowerShell см. в статье "Сведения о заданиях PowerShell".
контексты Azure с заданиями PowerShell
Задания PowerShell выполняются как отдельные процессы без присоединенного сеанса PowerShell, поэтому Azure учетные данные должны быть общими для них. Учетные данные передаются как объекты контекста Azure с помощью одного из следующих методов:
Автоматическое сохранение контекста. Сохраняемость контекста включена по умолчанию и сохраняет сведения о входе в нескольких сеансах. Если включена сохраняемость контекста, текущий Azure контекст передается в новый процесс:
Enable-AzContextAutosave # Enables context autosave if not already on $vmadmin = Get-Credential Start-Job { New-AzVM -Name MyVm -Credential $Using:vmadmin }Представьте объект контекста Azure вместе с любым командлетом Azure PowerShell с параметром AzContext.
$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 }Если сохраняемость контекста отключена, требуется параметр AzContext .
Используйте параметр AsJob, предоставляемый некоторыми командлетами Azure PowerShell. Этот переключатель автоматически запускает командлет в качестве задания PowerShell, используя активный контекст Azure.
$vmadmin = Get-Credential $job = New-AzVM -Name MyVm -Credential $vmadmin -AsJobЧтобы узнать, поддерживает ли командлет AsJob, проверьте его справочную документацию. Параметр AsJob не требует включения автосохранения контекста.
Вы можете проверить состояние выполняемого задания с помощью командлета Get-Job . Чтобы получить результаты задания на данный момент, используйте командлет Receive-Job.
Чтобы удаленно проверить ход выполнения операции на Azure, используйте командлеты Get, связанные с типом ресурса, изменяемого заданием:
$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
См. также
Azure PowerShell