Ошибка при запуске кода PowerShell в azure автоматизации - PullRequest
1 голос
/ 04 августа 2020

Я установил политику azure , добавив два тега: CreatedTime и Type. Значение CreatedTime равно utcNow(), формат по умолчанию 'yyyy-MM-ddTHH:mm:ss.fffffffZ'.

Моя цель - удалить все ресурсы, чей Тип равен private и время создания длиннее, чем 2 дня при запуске powershell код в azure автоматизация .

Я сделал это в Power Shell локально , но когда я запустил код в автоматизации , это не удалось. Я отправлю код и страницу с ошибкой ниже.

Кто-нибудь может сказать мне, что не так с моим кодом? Или я что-то пропустил?

Это мой код в Azure Автоматизация:

   $connectionName = "AzureRunAsConnection"
try
{
    # Get the connection "AzureRunAsConnection "
    $servicePrincipalConnection=Get-AutomationConnection -Name $connectionName         

    "Logging in to Azure..."
    Add-AzureRmAccount `
        -ServicePrincipal `
        -TenantId $servicePrincipalConnection.TenantId `
        -ApplicationId $servicePrincipalConnection.ApplicationId `
        -CertificateThumbprint 
$servicePrincipalConnection.CertificateThumbprint 
}
catch {
    if (!$servicePrincipalConnection)
    {
        $ErrorMessage = "Connection $connectionName not found."
        throw $ErrorMessage
    } else{
        Write-Error -Message $_.Exception
        throw $_.Exception
    }
}

    $AllRes = (get-AzureRMResource).ResourceId
    $TimeOutDays=2
    foreach ($Res in $AllRes){
    $Resource = Get-AzureRMResource -ResourceId $Res
    $Tags=$Resource.Tags
    $TypeInTags=$Tags['Type']
    $CreatedTimeInTags=$Tags['CreatedTime']
try{
    $CreatedTime=[Datetime]::ParseExact($CreatedTimeInTags, 'MM/dd/yyyy HH:mm:ss', $null)
}
catch{
    $CreatedTime=[Datetime]::ParseExact($CreatedTimeInTags, 'yyyy-MM-ddTHH:mm:ss.fffffffZ', $null)
}
finally
{
    $CreatedTime
}
    $daypan=((get-date)-$CreatedTime).Days
    if($TypeInTags -eq 'private')
    {
    if($daypan -gt $TimeOutDays)
        {
            $daypan
            Remove-AzureRMResource -ResourceId $Res -Force
        }
    }
}

Это страница ошибки: Приостановлено

The runbook job was attempted 3 times, but it failed each time.  Common reasons that runbook jobs fail can be found here:  https://docs.microsoft.com/en-us/azure/automation/automation-troubleshooting-automation-errors

enter image description here

A piece of error message:

Get-AzureRMResource : ResourceNotFound : The Resource 
'microsoft.alertsmanagement/smartDetectorAlertRules/Failure+Anomalies+-+arrowbottest2-config' under resource group 
'arrowbot2' was not found. For more details please go to https://aka.ms/ARMResourceNotFoundFix
At line:28 char:17
+     $Resource = Get-AzureRMResource -ResourceId $Res
+                 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : CloseError: (:) [Get-AzureRmResource], ErrorResponseMessageException
    + FullyQualifiedErrorId : 
ResourceNotFound,Microsoft.Azure.Commands.ResourceManager.Cmdlets.Implementation.GetAzureResourceCmdlet
 
Exception calling "ParseExact" with "3" argument(s): "String was not recognized as a valid DateTime."
At line:34 char:5
+     $CreatedTime=[Datetime]::ParseExact($Tags['CreatedTime'], 'yyyy-M ...
+     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [], MethodInvocationException
    + FullyQualifiedErrorId : FormatException
 
Cannot find an overload for "op_Subtraction" and the argument count: "2".
At line:35 char:5
+     $daypan=((get-date)-$CreatedTime).Days
+     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [], MethodException
    + FullyQualifiedErrorId : MethodCountCouldNotFindBest
 

Cannot find an overload for "op_Subtraction" and the argument count: "2".
At line:35 char:5
+     $daypan=((get-date)-$CreatedTime).Days
+     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [], MethodException
    + FullyQualifiedErrorId : MethodCountCouldNotFindBest
 
Exception calling "ParseExact" with "3" argument(s): "String was not recognized as a valid DateTime."
At line:34 char:5
+     $CreatedTime=[Datetime]::ParseExact($Tags['CreatedTime'], 'yyyy-M ...
+     ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [], MethodInvocationException
    + FullyQualifiedErrorId : FormatException

For the type of $Tags['CreatedTime'], I did this for a test: $Tags['CreatedTime'].GetType().FullName.

введите описание изображения здесь

Ответы [ 2 ]

0 голосов
/ 06 августа 2020

Ошибки в двух вещах.

1. Не указал нужный мне ресурс.

Подробности:

Это причина сообщения об ошибке: Can not index to a null array. Я просматриваю весь ресурс в своей подписке, но ресурсы, созданные до того, как я установил политику, не имеют тега с именем "CreatedTime" или "Type", поэтому при запуске $Tags=$Resource.Tags, он сказал Can not index to a null array.

Мое решение:

Сделайте $AllRes = (get-AzResource -TagName "CreatedTime").ResourceId кроме $AllRes = (get-AzureRMResource).ResourceId. Я обнаружил, что модуль AzureRM не распознает -TagName как переменную, поэтому я импортирую модуль Az и меняю каждый модуль AzureRM на модуль Az.

2. Путаница с utcNow ().

Подробности:

Как я уже сказал, с функцией utcNow () я получаю объект DateTime с форматом по умолчанию 'yyyy-MM-ddTHH:mm:ss.fffffffZ', после большого тестирования я нашел несколько специальные ресурсы, такие как значение тега application insight, не формируются с помощью 'yyyy-MM-ddTHH:mm:ss.fffffffZ', и когда я вызываю его, оно превращается в строку.

Мое решение:

Итак когда я использую его по сравнению с get-date, мне нужно сделать две вещи:

(1) заменить строку на объект DateTime;

(2) использовать try-catch для двух типов форматов.

0 голосов
/ 04 августа 2020

Поскольку вы говорите, что значение CreatedTime равно utcNow(), то это значение уже является объектом DateTime, и вы не должны рассматривать его как строку. (вы думаете, что это строка, потому что, когда вы записываете ее на консоль, она показывает свое ToString() представление)

Просто выполните

$CreatedTime=$Tags['CreatedTime']

Вы можно проверить это с помощью хоста записи $Tags['CreatedTime'].GetType().FullName

...