2016-03-05 119 views
0

我有一個Azure自動化PowerShell腳本,計劃每天晚上運行。出於某種原因,每當工作流程運行時,然後在運行工作流程的同一實例中再次開始運行所有命令。我沒有循環整個工作流程或任何東西,所以我不知道如何或爲什麼會發生這種情況。有什麼想法嗎?Azure自動化PowerShell腳本運行命令兩次

下面是代碼:

workflow Start-SQLDatabaseBackup 
{ 
     param(
     [parameter(Mandatory=$true)] 
     [string] $credName = 'automation', 

     [parameter(Mandatory=$true)] 
     [string] $SubscriptionName, 

     [parameter(Mandatory=$true)] 
     [string] $SQLServerName, 

     [parameter(Mandatory=$true)] 
     [string] $DatabaseName, 

     [parameter(Mandatory=$true)] 
     [string] $StorageAccountName, 

     [parameter(Mandatory=$true)] 
     [string] $ContainerName ='backup', 

     [parameter(Mandatory=$false)] 
     [string] $time 


    ) 
    inlinescript { 

     Write-Output ("Starting Database Backup for " + $Using:DatabaseName) 

     $Credential = Get-AutomationPSCredential -Name $Using:credName 
     if($Credential) 
     {    
      Write-Output ("Found Automation Credential Asset named " + $Using:credName) 
     } 
     else 
     { 
      throw ("Could not find an Automation Credential Asset named" + $Using:credName + ". Make sure you have created one in this Automation Account.") 
     }  

     $SQLCredential = Get-AutomationPSCredential -Name '****' 

     if($SQLCredential) 
     {    
      Write-Output ("Found SQL Credential Asset named " + $Using:SQLcredName) 
     } 
     else 
     { 
      throw ("Could not find an SQL Credential Asset named " + $Using:SQLcredName + ". Make sure you have created one in this Automation Account.") 
     } 


     Add-AzureAccount -Credential $Credential > $null 
     Select-AzureSubscription -SubscriptionName $Using:SubscriptionName 

     if (!(Test-AzureName -Storage $Using:StorageAccountName)) 
     { 
      Write-Output ("Creating Storage Account " + $Using:StorageAccountName) 
      New-AzureStorageAccount -StorageAccountName $Using:StorageAccountName -Location $Using:Location 
     } 

     Set-AzureSubscription -SubscriptionName $Using:SubscriptionName -CurrentStorageAccountName $Using:StorageAccountName 

     $SqlContext = New-AzureSqlDatabaseServerContext -ServerName $Using:SQLServerName -Credential $SQLCredential 
     if($SqlContext) 
     {    
      Write-Output ("Created SQL Context for " + $Using:SQLServerName) 
     } 
     else 
     { 
      throw ("Could not Create SQL Context for " + $Using:SQLServerName + ". Make sure SQL Credential Asset named" + $Using:SQLcredName + " has access to the server") 
     } 
     $time = $Using:time 
     if ([string]::IsNullOrEmpty($time)) 
     { 
      $start = [System.DateTime]::UtcNow 
      $time = $start.ToString("yyyyMMdd_hh-mm-ss-tt") 
     } 

     $fileName = ("{2}/{0}_{1}.bacpac" -f $Using:DatabaseName, $time, $time) 


     $Container = Get-AzureStorageContainer -Name $Using:ContainerName 
     if($Container) 
     {    
      Write-Output ("Retrieved Azure Storage Container - " + $Using:ContainerName) 
     } 
     else 
     { 
      throw ("Could not Retrieve Azure Storage Container " + $Using:ContainerName + ". Make sure the Storage Container exists. ") 
     } 
     Write-Output ("Starting Copy of " + $Using:DatabaseName) 

     $dbCopyName = ($Using:DatabaseName +"_copy") 
     $dbCopy = Start-AzureSqlDatabaseCopy -ServerName $Using:SQLServerName -DatabaseName $Using:DatabaseName -PartnerDatabase $dbCopyName 
     $doLoop = 1 

     while ($doLoop -eq 1) 
     { 
      $copyStatus = Get-AzureSqlDatabaseCopy -ServerName $Using:SQLServerName -DatabaseCopy $dbCopy -ErrorAction SilentlyContinue 
      if ($copyStatus -ne $null) 
      { 
       Write-Output $copyStatus.PercentComplete 
       Start-Sleep -s 10    
      } 
      else 
      { 
       $doLoop=0 
       Start-Sleep -s 10 
      } 
     } 
     Get-AzureSqlDatabase -ConnectionContext $SqlContext -DatabaseName $dbCopyName 

     Write-Output ("Starting Export of " + $dbCopyName) 
     $exportRequest = Start-AzureSqlDatabaseExport -SqlConnectionContext $SqlContext -StorageContainer $Container -DatabaseName $dbCopyName -BlobName $fileName 
     if ($exportRequest) 
     { 
      $doLoop = 1 
      while ($doLoop -eq 1) 
      { 
       $exportStatus = Get-AzureSqlDatabaseImportExportStatus -Request $exportRequest 
       if ($exportStatus.Status -eq "Completed") 
       { 
        $doLoop = 0    
       } 
       elseif ($exportStatus.Status -eq "Failed") 
       { 
        $doLoop = 0 
        throw ("Exporting database " + $dbCopyName + " failed") 
       } 
       else 
       { 
        Write-Output $exportStatus.Status 
        Start-Sleep -s 10 
       } 
      } 

      Write-Output ("Backup " + $fileName + " Created") 
     } 
     else 
     { 
      throw ("Error Creating Export Request for " + $dbCopyName) 
     } 
     Write-Output ("Deleting " + $dbCopyName) 
     Remove-AzureSqlDatabase -ConnectionContext $SqlContext -DatabaseName $dbCopyName -Force 

    } 
} 

這裏是輸出。您可以看到它在完成後再次從腳本的頂部運行命令。

Starting Database Backup for ***** 
    Found Automation Credential Asset named **** 
    Found SQL Credential Asset named 
    Created SQL Context for ***** 
    Retrieved Azure Storage Container - backup 
    Starting Copy of ****** 
    0 
    0 
    0 
    0 
    0 
    0 
    0 
    100 
    Starting Export of ****** 
    Pending 
    Running, Progress = 0% 
    **Starting Database Backup for ******** < -- Starts running from the top of script again? 
    Found Automation Credential Asset named **** 
    Found SQL Credential Asset named 
    Created SQL Context for ******* 
    Retrieved Azure Storage Container - backup 
    Starting Copy of ***** 
    Starting Export of ***** 

回答

1

您可能正在運行到Azure的自動化的"fair share"限制,我們卸載該時間超過3小時(以確保其他工作有機會運行),然後從它的最後一個檢查點恢復作業的任何作業(如果Runbook中沒有檢查點,就像你的情況一樣,工作將從頭開始)。

如果要確保在達到Azure Automation公平份額限制的情況下不重新運行Runbook的某些部分,請確保Runbook作業在三小時內完成,或添加檢查點(通過Checkpoint-Workflow )在不應該重複的部分Runbook之後。

+0

嗯...有趣。我認爲可能就是這樣。謝謝! – Bullsfan127