Jump to content
Kuddel071089

Anzahl Gruppenmitglieder vergleichen

Recommended Posts

Hallo zusammen,

 

auf Grund Ressourcenengpässen in unserer VMware Umgebung, wollen wir die Installation von WindowsUpdates auf mehrere Wochentage verteilen.

 

Aktuell startet die Installation immer am Dienstag um 3 Uhr.

 

Jetzt würden wir gern per AD-Gruppe und GPO den Installationstag festlegen (Montag bis Donnerstag).


Woran ich aktuell scheiter, ist der Vergleich der Mitglieder der einzelnen Gruppen.

 

Beim Ausrollen soll die VM automatisch in der AD-Gruppe mit den wenigsten Mitglieder landen:
 

Montag = 10 Server

Dienstag = 5 Server

Mittwoch = 9 Server

 

Der Server, bzw. das Computerobjekt, soll jetzt automatisch in der Gruppe für Dienstag landen und das GPO für Dienstag bekommen.

 

 

Hat jemand einen Tip, wie ich den Vergleich per Powershell hinbekomme?

 

 

 

 

Share this post


Link to post
Share on other sites

Wie sieht denn Dein Code bisher aus?

Mal ganz abstrakt betrachtet, liest Du die Gruppen aus, ermittelst deren Mitgliederzahl mit der .count() - Methode, die jedes Array mitbringt, sortierst die 3 Gruppen nach dieser Anzahl und nimmst die erste oder letzte - je nach dem, wie rum Du sortiert hast.  ;-)

Edited by BOfH_666

Share this post


Link to post
Share on other sites

Aktuell sieht es so aus:

 

cls
$groups = Get-ADGroup -Filter {Name -like "WSUS*"}

foreach($group in $groups) {

$anzahl = Get-ADGroupMember $group.Name
$anzahl.Count


}

Damit bekomme ich die MitgliederAnzahl ausgewertet.

 

Leider weiß ich jetzt nicht, wie ich diese Anzahlen miteinander verlgeichen kann

Share this post


Link to post
Share on other sites

Hab mal ein wenig rumgespielt:

 

$gruppe1 = 10
$gruppe2 = 100
$gruppe3 = 4000
$gruppe4 = 220

$array = [array]$gruppe1,$gruppe2,$gruppe3,$gruppe4
$min = $array | measure -Minimum
$min = $min.Minimum

if($gruppe1 -eq $min) {$gruppe = "Gruppe 1"}
if($gruppe2 -eq $min) {$gruppe = "Gruppe 2"}
if($gruppe3 -eq $min) {$gruppe = "Gruppe 3"}
if($gruppe4 -eq $min) {$gruppe = "Gruppe 4"}

$gruppe

Jetzt wird mir als Ergebnis "Gruppe 1" angezeigt, was in meinen Augen richtig ist

Share this post


Link to post
Share on other sites

Hi,

 

hier müsste quick'n'dirty deine Logik drin sein.

$Gruppen = @()

foreach ($Gruppe in (Get-ADGroup -Filter {Name -like "WSUS*"})){
    if($(Get-ADGroupMember $Gruppe.Name).Count -ge 0){
        $temp = New-Object PSObject -Property @{
                    Gruppe = $Gruppe.Name
                    Mitglieder = $(Get-ADGroupMember $Gruppe.Name).Count
                }  
        $Gruppen += $temp
    }
}
($Gruppen | Sort-Object Mitglieder)[0].Gruppe

Gruß

Jan

Share this post


Link to post
Share on other sites

Probier ma das hier:

$groups = Get-ADGroup -Filter { Name -like "WSUS*" }

$GroupList = foreach ($group in $groups) {
    [PSCustomObject]@{
        Group       = $group.name
        MemberCount = (Get-ADGroupMember -Identity $group.Name).count
    }
}
$GroupList | 
    Sort-Object -Property MemberCount

Wenn Du jetzt noch ein Select-Object -First 1 dran hängst, hast Du die Gruppe mit den wenigsten Mitgliedern.

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


Werbepartner:



×
×
  • Create New...