Следуя этим принципам вы сильно обезопасите свои серверы под управлением Windows как в локальных средах, так и в публичных.
1. Правильно вводим компьютер в AD
Не используйте пользователей с административными привилегиями для ввода компьютеров в Active Directory. Никто не гарантирует того, что на компьютере сотрудника уже не появился Keylogger. Имея же отдельную учетную запись. Злоумышленник похитивший учетные данные сможет только добавить в AD еще компьютеров.
1.1. Создаем нового пользователя
Для этого нужно перейти в ADUC (Active directory users and Computers). Нажать на пустое место в папке Users and Computers и создать пользователя. Для простоты назовем его JoinAdmin.
1.2. Делегируем полномочия
После того, как пользователь был создан, ему нужно назначить полномочия. Для этого нужно нажать ПКМ по папке «Users» и выбрать «Delegate Control». Жмём «Далее» и выбираем нашего админа.
Мы хотим чтобы пользователь выполнять только одну функцию, поэтому выбираем второй вариант.
Далее выбираем «Computer objects» и все его подпункты.
Используйте этого юзера и не беспокойтесь о том, что кто-то мог украсть пароль от администратора.
2. Controlled folder access
В Windows Server 2019 появилась очень недооцененная возможность — controlled folder access. Она запрещает доступ к записи программам, которых нет в белом списке на выбранных папках или разделах.
Её включение поможет защитить данные от вирусов-шифровальщиков даже если ваш сервер был заражен. Однако это не обезопасит ваши данные от похищения, их можно будет прочитать.
Включить функцию можно в центре безопасности Windows или через Powershell:
Set-MpPreference -EnableNetworkProtection Enabled
Добавляем разрешенные программы:
Разрешенные программы можно добавить через центр безопасности Windows, а через Powershell нужно вводить полный путь до исполняемых файлов через запятую.
Set-MpPreference -ControlledFolderAccessAllowedApplications "C:\Folder\File.exe"
Добавлять новые файлы в тот же самый список будет легче с помощью скрипта.
$ApplicationToAdd = "C:\Fodler\file.exe"
$ExistingApplicationList = (Get-MpPreference).ControlledFolderAccessAllowedApplications
$FullList = $ApplicationToAdd + $ExistingApplicationList
Set-MpPreference -ControlledFolderAccessAllowedApplications $FullList
Добавляем защищенные папки:
Папки добавляются ровно так же, как и программы. К примеру этой командой мы добавляем диск C: целиком:
Set-MpPreference -ControlledFolderAccessProtectedFolders "C:\"
3. SYSWOW64 и SMB
Все 32 битные программы работают на 64 битных через слой совместимости — SYSWOW64. Отключение этого компонента делает несовместимым все 32 битное ПО, в том числе и вирусы.
Сами по себе 32 битные приложения более уязвимые, 64-битные программы не поддаются атаке на переполнение буфера и через них гораздо труднее исполнить код который этими программами не предусмотрен. Если на сервере работают только встроенные компоненты или только 64 битные программы, обязательно удалите этот компонент.
А помните Wannacry, который гулял через SMB1? SMB первой версии до сих пор является стандартным компонентом Windows Server и установлен по умолчанию в каждой редакции.
Wannacry проникал через уязвимость EternalBlue, уязвимость пропатчили, но осадочек остался.
Эта команда удалить и SMB1 и SYSWOW64:
Remove-WindowsFeature WoW64-Support, FS-SMB1
Воспринимать рекомендацию стоит не как повод для удаления этих конкретных компонентов, но как отключение всех неиспользуемых компонентов в целом.
4. Отключите ping
По умолчанию компьютер под управлением Windows отвечает на ICMP только в локальной сети. Отключение ICMP немного повышает безопасность вашего сервера. Отчасти, это обусловлено тем, что на форумах кулхацкеров и других script kiddie существуют руководства, как нужно искать цели, которые можно брутфорсить.
Для того, чтобы показать что вы выиграете, если отключите ICMP, было создано два сервера. На обоих из них был открыт RDP, однако один из серверов не отвечал на ICMP.
ICMP отключен:
ICMP включен:
Как можно видеть из скриншота, это остановило не всех, но многих. Собрать данные о том, насколько сильно хотят взломать вас, можно этим скриптом:
function Get-Bruteforce {
$Last = 4
$Attempts = 10
#Getting date -one hour (default)
$DateTime = [DateTime]::Now.AddHours(-$Last)
$BruteEvents = Get-EventLog -LogName 'Security' -InstanceId 4625 -After $DateTime -ErrorAction SilentlyContinue | Select-Object @{n='IpAddress';e={$_.ReplacementStrings[-2]} }
$TopPunks = $BruteEvents | Group-Object -property IpAddress | Sort-Object Count
#Get bruteforsers that tried to login greated or equal than 4 times (default)
$GetPunks = $TopPunks | where {$_.Count -ge $attempts} | Select -property Name
Write-host Unique attackers IP: $GetPunks.Length -ForegroundColor Green
Write-Host Total bruteforce attempts: $BruteEvents.Length -ForegroundColor Green
#Output-punks
foreach ($i in $TopPunks | where {$_.Count -ge $attempts}) {
$PunkRdns = (Resolve-DnsName $i.Name -ErrorVariable ProcessError -ErrorAction SilentlyContinue).NameHost
if ($ShowRDNS) {
if ($PunkRdns) {
Write-Host "attempts": $i.count IP: $PunkRdns
}
else {
Write-Host "attempts": $i.count IP: $i.name
}
}
else {
Write-Host "attempts": $i.count IP: $i.name
}
}
}
Get-Bruteforce
Вы все еще сможете мониторить ваш сервер, к примеру, проверяя доступность определенного порта:
Test-NetConnection 192.168.0.1 -Port 3389
5. Не все имена одинаково хороши
Используя еще один скрипт, вытащим наиболее популярные имена пользователей, которые подвергались атаке.
Если вы устанавливаете службы удаленных рабочих столов, настоятельно рекомендуем вам избегать этих имен. В сочетании со слабым паролем, можно гарантировать быстрый взлом учетной записи.
Для вашего удобства, список «плохих» имен был переписан в таблицу:
Попыток взлома | Имя учетной записи |
---|---|
40 | ИРИНА |
41 | HOME |
42 | SKLAD |
42 | sqlserver |
42 | SYS |
42 | KASSA2 |
43 | ADMIN1 |
43 | ПК |
45 | ГОСТЬ |
46 | Host |
46 | Audit |
49 | USER3 |
54 | TEST1 |
55 | BUH2 |
66 | ПОЛЬЗОВАТЕЛЬ |
66 | MANAGER |
75 | ADM |
77 | .NET.v.4.5 |
80 | BUH1 |
86 | BACKUP |
89 | BUH |
90 | АДМИН |
100 | 1 |
116 | SERVER |
122 | User2 |
128 | A??E?E???A?I? |
147 | TEST |
219 | USER1 |
308 | USER |
330 | ADMIN |
9299 | ADMINISTRATOR |
13972 | АДМИНИСТРАТОР |
Получить такой же список на вашем сервере можно этим скриптом:
function Get-Badname {
$Last = 24
$Attempts = 40
$DateTime = [DateTime]::Now.AddHours(-$Last)
$BruteEvents = Get-EventLog -LogName 'Security' -InstanceId 4625 -After $DateTime -ErrorAction SilentlyContinue | Select-Object @{n='IpAddress';e={$_.ReplacementStrings[5]} }
$TopPunks = $BruteEvents | Group-Object -property IpAddress | Sort-Object Count
$GetPunks = $TopPunks | where {$_.Count -ge $attempts} | Select -property Name
Write-host Unique attackers IP: $GetPunks.Length -ForegroundColor Green
Write-Host Total bruteforce attempts: $BruteEvents.Length -ForegroundColor Green
#Output
foreach ($i in $TopPunks | where {$_.Count -ge $attempts}) {
Write-Host "Attempts": $i.count Username: $i.name
}
}
Get-Badname
6. Очевидные вещи
Ну а закончим мы статью очевидными вещами:
- Создайте шлюз – Для управления большой инфраструктурой лучше всего обезопасить себя имея единую точку входа. Подробне.
- Устанавливайте обновления. В особенности, на боевые сервера.
- Отключите службы, которыми вы не пользуетесь – это лишняя площадь для атаки.
- Используйте Server Core, он имеет наименьшую площадь атаки и наименьшее количество перезагрузок при установке обновлений
- Сервер удаленных рабочих столов на несколько пользователей – плохая идея. Придерживайтесь принципа один человек или служба – один сервер.
- Делайте резервные копии и обязательно тестируйте их. Бэкап, который не был протестирован не является бэкапом.
Надеемся, первые пять пунктов были для вас полезны и интересны.
Nova_Logic
Отключение ICMP -очень плохая практика, не надо его отключать ради какой-то выдуманной безопасности. Nmap порты просканирует и без пинга.
skymal4ik
Согласен, я тоже не поддерживаю отключение ICMP. Ладно ещё на публично доступных интерфейсах, там это можно как-то оправдать. Ито я бы ещё дважды подумал, какие именно ICMP сообщения отключать, и возможно разрешил бы его для внутренних сетей типа 192.168.0.0/16 и т.д.
А в локальной сети, где обычно находятся Windows-серверва — только усложните себе жизнь при сетевой диагностике, например.
ultra_vds Автор
Нам стоило оговориться, что отключать ICMP стоит именно в публичных сетях.
В локальных, наверное, эта проблема совсем не стоит.
maledog
Не имеет никакого смысла и в публичных сетях, т. к. не имеет смысла выставлять сервер с Windows напрямую в интернет, ну а нормальный firewall сумеет решить проблему со script kiddie.
Если же мы говорим про VDS/VPS тогда больше смысла в том, чтобы хотя бы спрятать RDP на нестандартный порт не говоря уже о том чтобы за VPN, чем отключать ICMP.
ultra_vds Автор
Рекомендация дана на основе случаев с нашими клиентами. Часто офисы не имеют белых IP адресов, а бухгалтера на аутсорсе, у которых так же нет белых ip адресов, поэтому на серверах удаленных рабочих столов порт RDP открыт для всего интернета.
maledog
Если у сервера нет белого адреса, то как же к нему по RDP подключаются? Через NAT провайдера?
И если RDP торчит открытым наружу, то почему рекомендуете закрыть ICMP вместо того, чтобы закрыть/защитить RDP? Для старых версий windows был 2x Secure RDP 4.0 — он затруднял перебор паролей. Возможно еще работает, на новых версиях windows не проверял.
По своему опыту могу сказать от логирования в данном случае мало проку. Журнал безопасности быстро забивается запросами, размер ограничен, работает медленно. А бот задорно продолжает перебор в несколько потоков. И ничего с ним сделать нельзя если нет нормального фаевола и чего-то похожего на fail2ban. Но те у кого это есть уже наверняка позаботились об удаленном доступе через vpn.
dmolokov
Скорее всего имелось ввиду то, что ограничить доступ на сервер только с одного офиса невозможно из-за того, что у данного офиса отсутствует белый IP. Поэтому серверу приходится светиться на весь интернет.
somurzakov
офисам надо завести VPN хотя бы, бухгалтерам поставить OpenVPN клиент и авторизацию по сертификату.
безопасность надо строить по слоям модели TCP/IP:
1. RDP это уровень приложения
2. OpenVPN это безопасность на транспортном уровне.
3. Также если известны диапазоны серых ИП-адресов провайдеров, которые используются клиентами, то их тоже надо внести в правила на фаерволе — это будет безопасность на сетевом уровне. Лучше закрыть доступ на несколько обширных диапазонов, чем открывать себя на весь мир
пример с ICMP не понял если честно, никакого профита он не даст, т.к. никакой сервер не должен полностью смотреть в мир однозначно, только принцип наименьших привилегий.
Dexterite
Есть альтернатива, куда более простая и нативная для Win, однако, более дорогая — RD Gateway. Она как раз и призвана защитить RDP без довешивания VPN.
— 2FA Через Ажур или с прикрученным Duo или еще как (NPS)
— TLS
somurzakov
все равно не стоит полагаться на один софт для защиты, если в RD Gateway будет уязвимость или 0day — то вся защита посыпется.
А плюсы эшелонированной защиты по слоям, что уязвимость в одном слое не приведет к такой сильному падению безопасности — это лучшие практики безопасности которые все вендоры ИБ рекомендуют
somurzakov
кстати вот буквально пару дней назад вышла новая уязвимость для RD Gateway (CVE-2020-0610) с рейтингом опасности 9.8 из 10. security.berkeley.edu/news/patch-immediately-microsoft-remote-desktop-gateway-remote-code-execution-vulnerability-cve-2020
Вот так и взламывают компании, которые надеются на одну тулзу и не строят эшелонированную безопасность на нескольких независимых уровнях