Авторизация
Теги сайта
0х0000007b 1c 1с access control list acl activation active directory ad roles add route adexplorer apache authentication to zabbix bare metal recovery bg zsh bicycle books bruteforce ccna centos centos packet certificate change net adapter name chap chkrootkit chmod cinnamon 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 disable ipv6 diskpart dism django dns domain naming master domain roles download download powershell enable routing on windows 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 inheritance iperf iptables iscsi jobs kernel panic ldap ldap аутентификация zabbix limit lingualeo linux mcitp mcsa 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 service permissions services session set dns servers set ip address sftp shell script show variables snmp sound scheme sounds speed ssh ssl standard-supfile subinacl supfile switch switchport sync syncronization task sсheduler tempdb 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 xrdp yum zabbix zabbix external check zabbix ldap authentication zsh автоматическое обновление портов freebsd автономные файлы активация английский язык база данных безопасность active directory буфер вело велосипед видео включение роутинга в windows внешняя проверка zabbix вредоносное программное обеспечение posix задание двумерного массива звуки звуковая схема идиомы иероглифы киев кодировка командная строка конфигурация сети маршрутизация маршруты в freebsd маршруты в redhat linux область обновление портов ограничения windows основные команды пакеты centos перевод перенос планировщик задач покатушки полет над днепром проблемы кодировки протокол путь развития в it разрешения служб windows регистрируем cmd скриптом недоступность хоста реестр резервирование ip скриптом роли домена русские символы синхронизация скачать скачать powershell скачать книгу скорость сети списки контроля доступа тарзанка твики фоновые процессы цикл mssql
Скрипт PowerShell для слития ролей Failover Cluster при проблеме с Team |
Данный скрипт перекинет все виртуальные машины с текущего узла кластера, если упадет агрегированный Team интерфейс (используется как транковый интерфейс для данных виртуальных машин). Также скрипт будет вести логирование в файл c:\DLC-TeamGroup.log и создавать файлы в корне диска C:\ которые можно использовать для других систем оповещения о проблеме.
<# This script will set current cluster node to maintance mode with drain roles if network team interface is down. When connection through team will restored, script resumes node from maintance mode and failbacks roles. You must add this script to Task Scheduler Original and comments: http://vam.in.ua/index.php/it/25-ms-powershell/196-powershell-scrript-to-drain-cluster-roles-if-team-interface-down.html Feedback: http://vam.in.ua/index.php/contacts/2-admins/1-aleksey.html #> Import-Module NetLbfo,FailoverClusters -ErrorAction Stop # Импортируем нужные модули [bool]$script:EverythingOkay = $true # Задаем переменную текущего состояния [bool]$script:TeamWasBad = $false # Задаем переменную предыдущего состояния [bool]$script:TeamWasDegraded = $false # Задаем переменную предыдущего состояния $script:cdtn = 0 # Задаем переменную для последующего цикла $script:LogPath = 'c:\DLC-TeamGroup.log' # Заносим в переменную путь к лог файлу [string]$script:TempVar = ' ' # Определяем рабочую текстовую переменную if (!(Test-Path -Path $LogPath)) # Если не существует лога { $private:FullScriptName = $MyInvocation.MyCommand.Definition # Записываем в переменную полный путь к скрипту Set-Content -Path $LogPath -Force -ErrorAction Stop -Value '# ', '# Log file for Team checking script', '# Original and comments: http://vam.in.ua/index.php/it/25-ms-powershell/196-powershell-scrript-to-drain-cluster-roles-if-team-interface-down.html', '# Feedback: http://vam.in.ua/index.php/contacts/2-admins/1-aleksey.html', "# Script path: $FullScriptName", '# ', '# ', ' ' # Создадим лог } while ($cdtn -eq 0) # Т.к. переменная $cdtn будет всегда равна нулю - цикл вечный { if ((Get-NetLbfoTeam).Status -eq 'Down') # Если тиминговая группа потеряла коннект { $TeamWasDegraded = $false # Наш Team полностью развалился, поэтому снимаем состояние Degraded if ( ($EverythingOkay -eq $true) -and ((Get-ClusterNode -Name "$env:COMPUTERNAME").State -eq 'Up') ) # Текущее состояние узла нормальное и нода не остановлена вручную { $EverythingOkay = $false # Записываем проблему в переменную $TempVar = (Suspend-ClusterNode -Drain | Out-String) # Переводим хост в режим обслуживания со слитием ролей на соседнюю ноду и записываем вывод действия в переменную Add-Content -Path $LogPath -Value '****** ============== ******', ((Get-Date -Format "yyyy.MM.dd HH:mm:ss" | Out-String) + "Teaming group has been DOWN"), $TempVar, " " # Добавляем запись в лог } else { if ($TeamWasBad -eq $false) # Если скрипт ранее не обнаруживал пробему с Team (нужно чтобы скрипт не записывал в лог одно и то же событие каждый проход цикла) { Add-Content -Path $LogPath -Value "****** ============== ******", ((Get-Date -Format "yyyy.MM.dd HH:mm:ss" | Out-String) + "Teaming group has been DOWN. Node hasn't gone into maintance mode"), " " # Добавляем запись в лог } } $TeamWasBad = $true # Указываем что скрипт обнаружил проблему с Team if (!(Test-Path -Path 'c:\DLC-TeamGroup_Down.tmp')) # Если нет файла { New-Item -Path 'c:\DLC-TeamGroup_Down.tmp' -ItemType File | Out-Null # Создаем файл (нужно для какого-либо внешнего мониторинга проблемы) } if (Test-Path -Path 'c:\DLC-TeamGroup_Degraded.tmp') # Если есть файл { Remove-Item -Path 'c:\DLC-TeamGroup_Degraded.tmp' -Force # Удаляем файл, т.к. у нас уже иное состояние } } if ((Get-NetLbfoTeam).Status -eq 'Up') # Если Team интерфейс в нормальном состоянии { if ( ($EverythingOkay -eq $false) -and ( (Get-ClusterNode -Name "$env:COMPUTERNAME").State -ne 'Up') ) # Если скрипт фиксировал с помощью переменной проблему с Team и текущий узел кластера не поднят { $TempVar = (Resume-ClusterNode -Failback Immediate | Out-String) # Выводим хост из режима обслуживания с фэилбэком ролей и записываем вывод действия в переменную Add-Content -Path $LogPath -Value "****** ============== ******", ((Get-Date -Format "yyyy.MM.dd HH:mm:ss" | Out-String) + "Teaming group has been UP"), $TempVar, " " # Добавляем запись в лог } else { if ($TeamWasBad -eq $true) # Если скрипт ранее обнаруживал проблему с Team { Add-Content -Path $LogPath -Value "****** ============== ******", ((Get-Date -Format "yyyy.MM.dd HH:mm:ss" | Out-String) + "Teaming group has been UP. Node hasn't resumed from maintance mode"), " " # Добавляем запись в лог } } $EverythingOkay = $true # Сообщаем в переменную что с Team все в порядке $TeamWasBad = $false # Снимаем состояние обнаружения проблемы $TeamWasDegraded = $false # Снимаем состояние Degraded if (Test-Path -Path 'c:\DLC-TeamGroup_Degraded.tmp') # Если есть файл { Remove-Item -Path 'c:\DLC-TeamGroup_Degraded.tmp' -Force # Удаляем его } if (Test-Path -Path 'c:\DLC-TeamGroup_Down.tmp') # Если есть файл { Remove-Item -Path 'c:\DLC-TeamGroup_Down.tmp' -Force # Удаляем его } } if ((Get-NetLbfoTeam).Status -eq 'Degraded') # Если состояние Team интерфейса Degraded { $TeamWasBad = $true # Указываем что скрипт обнаружил проблему с Team if ($TeamWasDegraded -eq $false) # Если скрипт еще не сделал запись в лог { Add-Content -Path $LogPath -Value "****** ============== ****** ", ((Get-Date -Format "yyyy.MM.dd HH:mm:ss" | Out-String) + "Teaming group has been DEGRADED"), " " # Добавляем запись в лог } $TeamWasDegraded = $true # Указываем что скрипту больше не нужно делать запись в лог по этому событию if (!(Test-Path -Path 'c:\DLC-TeamGroup_Degraded.tmp')) # Если нет файла { New-Item -Path 'c:\DLC-TeamGroup_Degraded.tmp' -ItemType File | Out-Null # Создадим файл } if (Test-Path -Path 'c:\DLC-TeamGroup_Down.tmp') # Если есть файл { Remove-Item -Path 'c:\DLC-TeamGroup_Down.tmp' -Force # Удалим файл, т.к. у нас уже иное состояние } } Start-Sleep -Seconds 59 # Ждем n секунд } |