Авторизация



Теги сайта



0х0000007b 1c access control list acl activation active directory ad roles add route adexplorer apache authentication to zabbix bare metal recovery bg zsh bicycle books bruteforce centos centos packet certificate change net adapter name chap chkrootkit chmod cisco class clipboard cmd configuring cpu cores cron crontab csc custom object cut cvsup cvsup-without-gui db dekorator dev null 2 1 dhcp dhcp reservation digitally signing script disable ipv6 diskpart dism django dns domain naming master domain roles download download powershell enabled encapsulation english english language esx eventlog fail2ban fastest_cvsup fedora fg zsh field formatdatabase freebsd fsmo get-aduser hardware https hyper-v idioms iis info php inheritance iperf iptables iscsi jobs kernel panic ldap ldap аутентификация zabbix limit lingualeo linux malware posix mcitp mcsa mcse memory check method microsoft mod_ssl mount mssql mysql mysql user password netcache network network config network load balance cluster network scripts nginx nlb num lock numlock oop openssl pap partition pdc permissions pfx php pipeline pkg_version polymorphism ports upgrade portupgrade posix powershell ppp puppet pwdlastset python rdp regedit registry remote enable restrictions reverse proxy rhel rid rope jumping bridge мост прыжок высота route add route freebsd routing protocol rpm sc sc sdset sc sdshow schema scope script output secure web security services set dns servers set ip address sftp shell script show variables snmp sound scheme sounds speed ssh ssl standard-supfile supfile switch switchport sync syncronization task sсheduler tempdb transfer role tripplite monitoring tweaks unix user must change password at next logon utf8 vim vlan vmware w32tm web windows windows 2003 r2 windows 2008 r2 windows firewall windows server windows server 2012 windows server backup windows service permissions windows пингалка winre wsus xargs yum zabbix zabbix external check zabbix ldap authentication zsh автоматическое обновление портов freebsd автономные файлы активация английский язык база данных безопасность active directory буфер вело велосипед видео внешняя проверка zabbix вредоносное программное обеспечение posix задание двумерного массива захват ролей dc звуки звуковая схема идиомы иероглифы киев кодировка командная строка конфигурация сети маршрутизация маршруты в freebsd маршруты в redhat linux область обновление портов ограничения windows основные команды пакеты centos перевод передача ролей dc перенос планировщик задач подписываем сценарий powershell покатушки полет над днепром проблемы кодировки протокол путь развития в it разрешения служб windows регистрируем cmd скриптом недоступность хоста реестр резервирование ip скриптом роли домена русские символы синхронизация скачать скачать powershell скачать книгу скорость сети списки контроля доступа тарзанка твики фоновые процессы цикл mssql

Главная страница Microsoft POWERSHELL Скрипт PowerShell для развертывания ролей на нескольких серверах
Скрипт PowerShell для развертывания ролей на нескольких серверах Печать

Для того, чтобы удаленно выполнить установку ролей и/или фитч на определенные компьютеры взятые из Active Directory, нам понадобятся:

  1. Сервер под управлением Windows Server 2012 с установленными средствами администрирования (RSAT) Active Directory module for Windows PowerShell из AD DS and AD LDS Tools;
  2. Шаблон установки в формате XML, описывающий что нужно устанавливать и как это все сконфигурировать;
  3. Установленная графическая платформа PowerShell_ISE;
  4. Скрипт PowerShell

 

Как создать шаблон установки DeploymentConfigTemplate.xml

Для этого нужно запустить Server Manager на Server 2012, из которого с помощью Add Roles and Features Wizard начать добавление и настройку всех необходимых ролей и фитч в обычном режиме, остановиться следует на этапе подтверждения Confirmation (рис. 1). В своем примере я буду добавлять на необходимые сервера фитчу Telnet Client.

На этапе Confirmation необходимо кликнуть на гиперссылку Export configuration settings и сохранить полученный XML файл конфига в удобное место.

image_ws2012_export-configuration-settings-for-installations

Рисунок 1

 

Скрипт развертывания

Import-Module ActiveDirectory,ServerManager # Импортируем нужные нам модули

$servers = Get-ADComputer -Filter * -Properties OperatingSystem | where {$_.OperatingSystem -match '.*?(server).*?(2012).*?'} # Записываем в переменную компьютеры из Active Directory с операционной системой Windows Server 2012
$selected = ($servers.Name | Out-GridView -Title "Select Servers to Configure" -PassThru -ErrorAction Stop) # Записываем в переменную имена компьютеров, которые можно будет выбрать в интерактивном окне. Для этого необходима установленная платформа Powershell_ISE

$sb = {param ($s,$f) Install-WindowsFeature -ComputerName $s -ConfigurationFilePath $f} # Формируем скрипт-блок. Задаем временные переменные, которые будут брать на себя меняющиеся значения параметров командлета Install-WindowsFeature

$configfile = 'C:\Templates\DeploymentConfigTemplate_TelnetClient.xml' # Указываем куда мы сохранили конфиг

foreach ($server in $selected) # Для каждого сервера из выбранных в интерактивном режиме выполнять
{    
    Start-Job -Name $server -ScriptBlock $sb -ArgumentList ($server,$configfile) # Стартуем задачу, вызывающую подготовленный скрипт-блок и передающую ему соответствующие параметры. Как посмотреть вывод задач я описывал в статье http://vam.in.ua/index.php/it/25-ms-powershell/149-powershell-background-tasks.html
}

Комментарии:

 
Главная страница Microsoft POWERSHELL Скрипт PowerShell для развертывания ролей на нескольких серверах