haschked
Goto Top

Gruppenrichtlinie Computerobjekte

Hallo,
ich habe mir eine GPO gebaut wo über die GPPs im Computerteil eine Datei ersetzt wird und anschl. ein Dienst neu gestartet wird.
Wenn ich das Computerobjekt direkt in die Sicherheitsfilterung packe wird es nach der nächsten Richtlinienverarbeitung angewendet.
Wenn ich aber im Sicherheitsfilter der GPO eine Gruppe packe und innerhalb der Gruppe ein Computerobjekt hinzufüge dann wird es nicht verarbeitet. Ich vermute der Computer muss erst neu angemeldet werden oder?

Jemand evtl. eine Idee wie ich das sonst lösen könnte? Es handelt sich um Serversysteme. Und jedes Computerobjekt einzeln in den Sicherheitsfilter zu packen ist leider sehr mühsam......

Danke und VG
Dennis

Content-ID: 669971

Url: https://administrator.de/forum/gruppenrichtlinie-computerobjekte-669971.html

Ausgedruckt am: 22.01.2025 um 08:01 Uhr

151081
Lösung 151081 04.12.2024 aktualisiert um 14:39:19 Uhr
Goto Top
Wenn ich aber im Sicherheitsfilter der GPO eine Gruppe packe und innerhalb der Gruppe ein Computerobjekt hinzufüge dann wird es nicht verarbeitet.
Ich vermute der Computer muss erst neu angemeldet werden oder?
Abmelden reicht nicht, er muss entweder neu gestartet oder das Computer-Kerberos-Ticket gelöscht werden. Damit ein Computer das Token für die Gruppenmitgliedschaft erhält muss er sein Kerberos Ticket erst erneuern, wenn man den Computer nach dem Hinzufügen zur Gruppe zwischenzeitlich nicht neu gestartet hat oder das Kerberos Tickt gelöscht hat.

Also den Computer entweder neu starten oder das Kerberos Ticket des Computers in einer elevated Shell mit psexec und dem "SYSTEM" Account löschen und ein gpudpate hinterher schieben.
psexec -s klist purge
gpupdate /force
Wenn kein psexec gewünscht ist, geht alternativ auch ein Scheduled Task mt SYSTEM-Rechten welcher den klist purge Befehl ausführt.
HaschkeD
HaschkeD 04.12.2024 um 12:21:42 Uhr
Goto Top
Danke f. d. Antwort.
OK, Mist face-sad
Neu starten ist bei den Serversystemen nicht ganz so einfach......
Ne Möglichkeit das Remote per psexec auf den Systemen auszuführen?
Per Scheduled Task über GPP hätte ich ja wieder das gleiche Problem das er entweder Reboot braucht oder das Kerberos Ticket gelöscht werden muss.
151081
151081 04.12.2024 aktualisiert um 12:52:52 Uhr
Goto Top
Zitat von @HaschkeD:
Neu starten ist bei den Serversystemen nicht ganz so einfach......
Jeder Server muss irgendwann mal neu gestartet werden, einfach ins Wartungsintervall verlegen oder Gruppen in der GPO nutzen in denen die Server bereits schon vorher Mitglied sind.
Ne Möglichkeit das Remote per psexec auf den Systemen auszuführen?
Klar direkt über psexec machen, das kann auch remote genutzt werden.
Oder ne Powershell Session öffnen. Enter-PSSession oder Invoke-Command oder WMI und Win32_Process

Per Scheduled Task über GPP hätte ich ja wieder das gleiche Problem das er entweder Reboot braucht oder das Kerberos Ticket gelöscht werden muss.
Nicht wenn du es direkt drauf pushst z.B. per Skript, oder die Computer alle einmalig per Powershell Skript in die GPO packst => Mit Get-ADComputer die Computer holen und mit Set-GPPermission in der GPO hinzufügen.
foreach ($computer in Get-ADComputer -Filter "Operatingsystem -like '*Server*' and enabled -eq 'true'" -Properties OperatingSystem){  
    Set-GPPermission -Name "Blablub" -TargetName $computer.Name -TargetType Computer -PermissionLevel GpoApply  
}
emeriks
emeriks 04.12.2024 aktualisiert um 14:35:54 Uhr
Goto Top
Ne Möglichkeit das Remote per psexec auf den Systemen auszuführen?
Wie @151081 schreibt: Über psexec

psexec \\servername -s klist purge

Edit:
Oder erst ne CMD starten und dann in dieser das klist und gpupdate ausführen. Wichtig ist nur Schalter "-s" - als SYSTEM.

psexec \\servername -s cmd
CamelCase
CamelCase 04.12.2024 um 16:43:56 Uhr
Goto Top
Ich nutze gerne Invoke-CommandAs

Invoke-CommandAs -ComputerName servername -AsSystem -ScriptBlock {klist purge}
HaschkeD
Lösung HaschkeD 05.12.2024 um 09:23:02 Uhr
Goto Top
Vielen Dank euch allen....top.

Habe es jetzt über PS gemacht:

$GPOname = "GPO NAME"  
$Domain = "xxx.xxx"  
 
# In Datei nur einen HOSTNAME pro Zeile
$Computers = Get-Content "C:\Temp\Server.txt"  
 
Write-Host "Add Computers to GPO Security Filtering" -ForegroundColor Yellow  
 
foreach ($Computer in $Computers){
    Write-Host "Add" $Computer -ForegroundColor Green   
    Set-GPPermissions -Name $GPOName -PermissionLevel GpoApply -TargetName $Computer -TargetType Computer -Domain $Domain
}