Управление компьютерами в AD
Приветствую и прошу совета у местных гуру скриптовых языков.
Ситуация такова. Есть домен, в котором много компов разного "срока годности". Я задался целью отыскать такие компы и решил использовать для этого Powershell. Так как в нем я не силен вовсе, то путем гугления нашел и состряпал такую команду: Get-ADComputer -LDAPFilter "(operatingsystem=*windows*)" -SearchBase "dc=domain_name,dc=ru" -Properties Name, IPv4Address, whenchanged, operatingsystem, lastlogondate, canonicalname, OperatingSystemServicePack | Out-GridView Потом я сортирую в открывшемся окне от GridView компы по атрибутам whenchanged и lastlogondate, задавая нужное мне условие по срокам, ОС и пр. Команда в принципе рабочая, но ее результаты требуют еще доп усилий для приведения в нужный мне вид. Что хотелось бы получить: 1. Выгрузку из AD только тех ПК, которые удовлетворяют условиям по параметрам whenchanged и lastlogondate (или какой-нибудь универсальный вариант чтобы я сам мог менять); 2. Выгрузку из AD сразу в файл SCV/XLSX/пр. желательно с шапкой; 3. Возможность выгрузить только имена ПК в файл TXT; 4. Возможность отключать/включать учетные записи ПК, которые получены выгрузкой выше или внесенные в файл руками; 5. Возможность удалять ПК, которые удовлетворяют условиям по параметрам whenchanged и lastlogondate и enabled. Буду еще благодарен за ссылки на ресурсы, на которых можно найти какие-нибудь другие крутые и забойные скрипты Powershell для работы с AD. |
1.
$wcdate = "{0:yyyMMddHHmmss}.Z" -f (Get-Date).AddDays(-90) $lldate = (Get-Date).AddDays(-90).ToFileTime() $users = Get-ADUser -Filter "whenChanged -ge '$wcdate' -and lastlogon -ge '$lldate'" 2. $users | Export-Csv result.csv -NoTypeInformation -Encoding UTF8 3. Get-ADComputer -Filter * | Foreach {$_.Name} | Out-File result.txt 4. http://forum.oszone.net/thread-280936.html 5. Get-ADComputer -Filter "whenChanged -ge '$wcdate' -and lastlogon -ge '$lldate' -and Enabled -eq $false" | Remove-ADComputer -Confirm:$false |
Как вариант.
Поиск устаревших компьютеров по параметру Passwordlastset (когда последний раз менялся пароль) Get-ADComputer -filter "Passwordlastset -lt '1/11/2013'" -properties * | Select name, passwordlastset |
Kazun, подскажите, пожалуйста, как этим пользоваться? Я открыл Windows PowerShell ISE, скопировал все строки из п. 1 и нажал F5. Что дальше?
|
Kazun, приветствую!
Ваш скрипт, к сожалению, не делает того, что должен. Он а) выгружает пользователей, а не ПК и б) он выгружает что угодно, но не компы, которые по указанным параметрам старше заданного числа дней. |
См. пункт 5,там ответ на а и на б. -ge - условие заменить на свое.
|
Kazun, вот, что я запускаю у себя после изменений:
$wcdate = "{0:yyyMMddHHmmss}.Z" -f (Get-Date).AddDays(-28) $lldate = (Get-Date).AddDays(-28).ToFileTime() $users = Get-ADComputer -Filter "whenChanged -ge '$wcdate' -and lastlogon -ge '$lldate'" Get-ADComputer -Filter "whenChanged -ge '$wcdate' -and lastlogon -ge '$lldate'" | Out-GridView В итоге получаю неправильный список компов. Хочу получить список ПК с несерверными Windows и атрибутами whenChanged и lastlogondate более 28 дней. Где у меня ошибка? Я понимаю, что вопросы тупые, но я не силен в PS. |
Код:
$wcdate = "{0:yyyMMddHHmmss}.Z" -f (Get-Date).AddDays(-28) |
Kazun, а вы не просвятите что такое -ge и что это выражение делает? Вы заменили его на -lt, а что делает оно? Я попробовал загуглить, но гугл не сознается, вероятно я неправильно спрашиваю.
|
Цитата:
|
Iska, а почему тогда нельзя сразу задать значение? Зачем нужны переменные $wcdate и $lldate?
|
Цитата:
|
Ищу, ищу, никак не найду, что означают whenChanged. Это значение всегда более позднее, чем LastLogOn .
Три компьютера, которые отобрались по критерию даты (также искал те, которые не работают больше 8 дней, почему-то безопасникам восемь дней понравились), так вот они пропинговались, то есть в данный момент в сети. |
WhenChanged is an attribute in Microsoft Active Directory and is the date when this object was last changed.
Собственно, то и означает - когда объект был изменён. http://www.selfadsi.org/user-attributes-w2k12.htm |
Время: 18:33. |
Время: 18:33.
© OSzone.net 2001-