Así que, después de la investigación, mi suposición inicial fue en parte equivocada: las llamadas a los nuevos cmdlets de PowerShell hacer esperar que se complete con éxito, excepto para Set-AzureDeployment -newStatus "Running"
.
Esto es bueno, ya que no necesitamos tener llamadas a Get-OperationStatus
dispersas a través de la secuencia de comandos; es malo, sin embargo, ya que Set-AzureDeployment
deja la implementación girando hacia arriba.
Sin embargo, podemos llamar al Get-AzureDeployment
y repetir el RoleInstanceList
para descubrir qué está pasando. Como tal:
function Get-StagingReady {
$stagingStatus = Get-AzureDeployment $azureService -slot staging
if (-not $($stagingStatus.Status -eq "Running")) {
Write-Host $(" ... ... Staging slot status is not Running; value is " + $stagingStatus.Running)
return $False
}
if (-not $stagingStatus.RoleInstanceList) {
Write-Host " ... ... Staging slot has no instances configured yet."
return $False
}
$notReady = $False
Foreach ($roleInstance in $stagingStatus.RoleInstanceList) {
if (-not $($roleInstance.InstanceStatus -eq "ReadyRole")) {
Write-Host $(" ... ... ... Staging slot instance " + $roleInstance.InstanceName + " has status " + $roleInstance.InstanceStatus)
$notReady = $True
}
}
if ($notReady) {
Write-Host " ... ... One or more instances not running."
return $False
}
Write-Host " ... Staging slot ready for use."
return $True
}
function Wait-ForStagingToBeReady {
while (-not $(Get-StagingReady)) {
Write-Host " ... ... Staging slot not ready, waiting 15 seconds for Azure to spin up instances."
Start-Sleep -s 15
}
}
function Start-Staging {
Write-Host " ... Starting staging slot."
$staging = Get-Staging $azureService
$result = Set-AzureDeployment `
-Status `
-serviceName $azureService `
-slot "Staging" `
-newStatus "Running"
if (-not $?) {
Write-Host
Write-Host "Unable to start staging slot."
Write-Host "DEPLOY FAILED"
Write-Host
exit 1
}
Wait-ForStagingToBeReady
Write-Host " ... Deployment in Staging slot started."
}
Además, parece que no puedo instalar las versiones anteriores de los cmdlets de Powershell; fallan en el comprobador de dependencias, ya que parece que 1.6 del SDK ya no está disponible ... –
v1.6 La descarga del SDK es [aquí] (http://www.microsoft.com/en-us/download) /details.aspx?id=28045), en caso de que decida ir por esa ruta. –
Ver mi respuesta a continuación. En general, los cmdlets _do_ esperan a completarse, excepto 'Set-AzureDeployment', que es, por supuesto, el que nos gustaría esperar. Pero tenemos los bits relevantes que necesitaremos para ordenar esto. –