Объединение имени учетной записи хранения и SKU с именем виртуальной машины в Powershell - PullRequest
0 голосов
/ 22 февраля 2019

Я хочу добавить StorageAccountName и его SKU к моему отчету, вот код, который у меня сейчас есть:

VMs = Get-AzureRmVM -Status

 $vmOutput = $VMs | ForEach-Object {
 [PSCustomObject]@{
 "VM Name" = $_.name
 "Private IP" =""
 "VM Type" = $_.StorageProfile.osDisk.osType
 "VM Profile" = $_.HardwareProfile.VmSize
 "Environment" = $_.Tags.Environment
 "Application" = $_.Tags.Application
 "Decommission Date" = $_.Tags.Decomission
 "OS Disk Size" = $_.StorageProfile.OsDisk.DiskSizeGB
 "Data Disks Total Size" = ($_.StorageProfile.DataDisks.DiskSizeGB | Measure -Sum).Sum
 "Data Disks Amount" = ($_.StorageProfile.DataDisks | Measure ).Count
 "Managed OS Disk" = ($_.StorageProfile.OSDisk.ManagedDisk | Measure).Count
 "Managed Data Disks" = ($_.StorageProfile.DataDisks.ManagedDisk | Measure).Count
 "Powerstate" = $_.PowerState
 }
 }

 $nics = get-azurermnetworkinterface | where VirtualMachine -NE $null
 $ips =@{}

 foreach($nic in $nics){
 $vm = $VMs | Where-Object -Property id -EQ $nic.VirtualMachine.id
 $prv = $nic.IpConfigurations | select-object -ExpandProperty PrivateIpAddress
 $ips.Add($vm.Name,$prv)
 }

 foreach($vm in $vmOutput)
 {
 if($ips.ContainsKey($vm."VM Name"))
 {
 $vm."Private IP"=$ips[$vm."VM Name"]
 }
 }

 $vmOutput | sort "Environment", "VM Type", "VM Profile", "Application" | export-csv VMReport.csv -delimiter ";" -force -notypeinformation

Я пытался сделать это более менее так же, как IP-адреса былиреализован в этом коде , но это намного сложнее, чем я ожидал, так как командлет Get-AzureRmStorageAccount не хранит свойство VirtualMachine.Id, как это делает командлет Get-AzureRMNetworkInterface.

Есть идеи, как объединить это в одну таблицу?Есть ли какой-нибудь ключ, по которому я могу присоединиться к обеим данным?Я хочу добавить столбцы StorageAccountName и SKUName в таблицу $ vmOutput.

Обновление:

$sat =@{}

$OutFile = "..."

#part1

foreach ($vmdetails in $VMs)
{
$ResourceGroupName=$vmdetails.ResourceGroupName
$VMName=$vmdetails.name
$storage=$vmdetails.StorageProfile.OsDisk.Vhd.Uri
$DataDiks=$vmdetails.StorageProfile.OsDisk.Name
$ss=$storage.split('/')[2]

$OSStorageAccountName=$ss.split('.')[0]
$DiskType="OSDisk"
$StroageAccountLocation=($StroageAccDetail | where  {$_.StorageAccountName -eq $OSStorageAccountName }).location
$StorageAccountType=($StroageAccDetail | where  {$_.StorageAccountName -eq $OSStorageAccountName }).AccountType
"$sub,$ResourceGroupName,$VMName,$DataDiks,$DiskType,$OSStorageAccountName" | Out-File -FilePath $OutFile -Append

$vmdatadisks=$vmdetails.StorageProfile.DataDisks

if($vmdatadisks -ne $null){
foreach($vmDatadsik in $vmdatadisks)
{
$vmDatadsikss=$vmDatadsik.vhd.uri
$DiskType="DataDisk"
$ss=$vmDatadsikss.split('/')[2]
$DataDiks=$vmDatadsik.Name
$dataStorageAccountName=$ss.split('.')[0]
"$sub,$ResourceGroupName,$VMName,$DataDiks,$DiskType,$OSStorageAccountName" | Out-File -FilePath $OutFile -Append
}
}
}

#part2

$VMs = Get-AzureRmVM -ResourceGroupName "..." -Name "..."
$storageAccountName = $VMs.StorageProfile.OsDisk.Vhd.Uri.Split("/")[2].Split(".")[0]
Get-AzureRmStorageAccount -StorageAccountName $storageAccountName -ResourceGroupName "..."

1 Ответ

0 голосов
/ 25 февраля 2019

Пожалуйста, исправьте меня, если я вас неправильно понимаю.

Предполагая, что sku относится к sku хранилища учетной записи, вы также можете добавить заполнители в $ vmOutput для имени SA и SKUName.

 $VMs = Get-AzureRmVM -Status  

 $vmOutput = $VMs | ForEach-Object {
 [PSCustomObject]@{
 "VM Name" = $_.name
 "ResourceGroupName" =$_.ResourceGroupName #you must include this parameter
 "storage" = $_.StorageProfile.OsDisk.Vhd.Uri #you must include this parameter
 #your other property
 #add placeholder for SA Name and SKUName like below
 "StorageAccountName" =""
 "StorageAccountSKUName" =""
}
}

Затем выполните итерацию всех vms в $ vmoutput и найдите соответствующую учетную запись хранения и sku, затем добавьте значение к $ vmoutput:

foreach($v in $vmOutput){
$resourceGroups = $v.ResourceGroupName
$storage=$v.storage

if($storage -ne $null)
{
$ss=$storage.split('/')[2]
$OSStorageAccountName=$ss.split('.')[0]

$s1 = Get-AzureRmStorageAccount -ResourceGroupName $resourceGroups -StorageAccountName $OSStorageAccountName

#add the value to $vmoutput
$v.StorageAccountName =$OSStorageAccountName
$v.StorageAccountSKUName=$s1.Sku.name
}
else
{
$v.StorageAccountName ="no value"
$v.StorageAccountSKUName="no value"
}
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...