Авторизация



Теги сайта



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 для слития ролей Failover Cluster при проблеме с Team
Скрипт 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 секунд

}

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

 
Главная страница Microsoft POWERSHELL Скрипт PowerShell для слития ролей Failover Cluster при проблеме с Team