рдореА рдЬреНрдпрд╛ рд╕рдВрд╕реНрдереЗрдд рдХрд╛рдо рдХрд░рддреЛ рддреНрдпрд╛ рд╕рдВрд╕реНрдереЗрдд рджреВрд░рд╕реНрде рдХрд╛рдо рдХрд░рдгреНрдпрд╛рд╕ рддрддреНрддреНрд╡рддрдГ рдордирд╛рдИ рдЖрд╣реЗ. рд╣реЛрддреЗ. рдЧреЗрд▓реНрдпрд╛ рдЖрдард╡рдбреНрдпрд╛рдкрд░реНрдпрдВрдд. рдЖрддрд╛ рдЖрдореНрд╣рд╛рд▓рд╛ рддрд╛рддрдбреАрдиреЗ рддреЛрдбрдЧрд╛ рдХрд╛рдврд╛рдпрдЪрд╛ рд╣реЛрддрд╛. рд╡реНрдпрд╡рд╕рд╛рдпрд╛рдХрдбреВрди - рдирд╡реАрди рдХрд╛рд░реНрдп рд╕реНрд╡рд░реВрдкрд╛рдордзреНрдпреЗ рдкреНрд░рдХреНрд░рд┐рдпрд╛рдВрдЪреЗ рд░реБрдкрд╛рдВрддрд░ рдХрд░рдгреЗ, рдЖрдордЪреНрдпрд╛рдХрдбреВрди - PIN рдХреЛрдб рдЖрдгрд┐ рдЯреЛрдХрдирд╕рд╣ PKI, VPN, рддрдкрд╢реАрд▓рд╡рд╛рд░ рд▓реЙрдЧрд┐рдВрдЧ рдЖрдгрд┐ рдмрд░реЗрдЪ рдХрд╛рд╣реА.
рдЗрддрд░ рдЧреЛрд╖реНрдЯреАрдВрдмрд░реЛрдмрд░рдЪ, рдореА рд░рд┐рдореЛрдЯ рдбреЗрд╕реНрдХрдЯреЙрдк рдЗрдиреНрдлреНрд░рд╛рд╕реНрдЯреНрд░рдХреНрдЪрд░ рдЙрд░реНрдл тАЛтАЛрдЯрд░реНрдорд┐рдирд▓ рд╕рд░реНрд╡реНрд╣рд┐рд╕реЗрд╕ рд╕реЗрдЯ рдХрд░рдд рд╣реЛрддреЛ. рдЖрдордЪреНрдпрд╛рдХрдбреЗ рд╡реЗрдЧрд╡реЗрдЧрд│реНрдпрд╛ рдбреЗрдЯрд╛ рд╕реЗрдВрдЯрд░рдордзреНрдпреЗ рдЕрдиреЗрдХ RDS рддреИрдирд╛рдд рдЖрд╣реЗрдд. рд╕рдВрдмрдВрдзрд┐рдд рдЖрдпрдЯреА рд╡рд┐рднрд╛рдЧрд╛рддреАрд▓ рд╕рд╣рдХрд╛рд▒реНрдпрд╛рдВрдирд╛ рд╡рд╛рдкрд░рдХрд░реНрддрд╛ рд╕рддреНрд░рд╛рдВрд╢реА рдкрд░рд╕реНрдкрд░рд╕рдВрд╡рд╛рджреАрдкрдгреЗ рдХрдиреЗрдХреНрдЯ рд╣реЛрдгреНрдпрд╛рд╕рд╛рдареА рд╕рдХреНрд╖рдо рдХрд░рдгреЗ рд╣реЗ рдПрдХ рдзреНрдпреЗрдп рд╣реЛрддреЗ. рддреБрдореНрд╣рд╛рд▓рд╛ рдорд╛рд╣рд┐рддреА рдЖрд╣реЗрдЪ рдХреА, рдпрд╛рд╕рд╛рдареА рдПрдХ рдорд╛рдирдХ RDS рд╢реЕрдбреЛ рдпрдВрддреНрд░рдгрд╛ рдЖрд╣реЗ, рдЖрдгрд┐ рддреЗ рд╕реЛрдкрд╡рдгреНрдпрд╛рдЪрд╛ рд╕рд░реНрд╡рд╛рдд рд╕реЛрдкрд╛ рдорд╛рд░реНрдЧ рдореНрд╣рдгрдЬреЗ RDS рд╕рд░реНрд╡реНрд╣рд░рд╡рд░ рд╕реНрдерд╛рдирд┐рдХ рдкреНрд░рд╢рд╛рд╕рдХ рдЕрдзрд┐рдХрд╛рд░ рджреЗрдгреЗ.
рдореА рдорд╛рдЭреНрдпрд╛ рд╕рд╣рдХрд╛рд░реНтАНрдпрд╛рдВрдЪрд╛ рдЖрджрд░ рдХрд░рддреЛ рдЖрдгрд┐ рддреНрдпрд╛рдВрдЪреА рдХрджрд░ рдХрд░рддреЛ, рдкрд░рдВрддреБ рдЬреЗрд╡реНрд╣рд╛ рдкреНрд░рд╢рд╛рд╕рдХ рдЕрдзрд┐рдХрд╛рд░ рджреЗрдгреНрдпрд╛рдЪреНрдпрд╛ рдмрд╛рдмрддреАрдд рдореА рдЦреВрдк рд▓реЛрднреА рдЕрд╕рддреЛ. ЁЯЩВ рдЬреЗ рдорд╛рдЭреНрдпрд╛рд╢реА рд╕рд╣рдордд рдЖрд╣реЗрдд, рдХреГрдкрдпрд╛ рдХрдЯ рдлреЙрд▓реЛ рдХрд░рд╛.
рдмрд░рдВ, рдХрд╛рд░реНрдп рд╕реНрдкрд╖реНрдЯ рдЖрд╣реЗ, рдЖрддрд╛ рд╡реНрдпрд╡рд╕рд╛рдпрд╛рдд рдЙрддрд░реВрдпрд╛.
1 рдкрд╛рдКрд▓
рдЪрд▓рд╛ Active Directory рдордзреНрдпреЗ рдПрдХ рд╕реБрд░рдХреНрд╖рд╛ рдЧрдЯ рддрдпрд╛рд░ рдХрд░реВ RDP_Operators рдЖрдгрд┐ рддреНрдпрд╛рдд рддреНрдпрд╛ рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдВрдЪреА рдЦрд╛рддреА рд╕рдорд╛рд╡рд┐рд╖реНрдЯ рдХрд░рд╛ рдЬреНрдпрд╛рдВрдирд╛ рдЖрдореНрд╣реА рдЕрдзрд┐рдХрд╛рд░ рд╕реЛрдкрд╡реВ рдЗрдЪреНрдЫрд┐рддреЛ:
$Users = @(
"UserLogin1",
"UserLogin2",
"UserLogin3"
)
$Group = "RDP_Operators"
New-ADGroup -Name $Group -GroupCategory Security -GroupScope DomainLocal
Add-ADGroupMember -Identity $Group -Members $Users
рддреБрдордЪреНрдпрд╛рдХрдбреЗ рдПрдХрд╛рдзрд┐рдХ AD рд╕рд╛рдЗрдЯреНрд╕ рдЕрд╕рд▓реНрдпрд╛рд╕, рдкреБрдвреАрд▓ рдЪрд░рдгрд╛рд╡рд░ рдЬрд╛рдгреНрдпрд╛рдкреВрд░реНрд╡реА рд╕рд░реНрд╡ рдбреЛрдореЗрди рдирд┐рдпрдВрддреНрд░рдХрд╛рдВрд╡рд░ рдкреНрд░рддрд┐рдХреГрддреА рддрдпрд╛рд░ рд╣реЛрдИрдкрд░реНрдпрдВрдд рддреБрдореНрд╣рд╛рд▓рд╛ рдкреНрд░рддреАрдХреНрд╖рд╛ рдХрд░рд╛рд╡реА рд▓рд╛рдЧреЗрд▓. рдпрд╛рд╕ рд╕рд╣рд╕рд╛ 15 рдорд┐рдирд┐рдЯрд╛рдВрдкреЗрдХреНрд╖рд╛ рдЬрд╛рд╕реНрдд рд╡реЗрд│ рд▓рд╛рдЧрдд рдирд╛рд╣реА.
2 рдкрд╛рдКрд▓
рдкреНрд░рддреНрдпреЗрдХ RDSH рд╕рд░реНрд╡реНрд╣рд░рд╡рд░ рдЯрд░реНрдорд┐рдирд▓ рд╕рддреНрд░реЗ рд╡реНрдпрд╡рд╕реНрдерд╛рдкрд┐рдд рдХрд░рдгреНрдпрд╛рдЪреЗ рдЕрдзрд┐рдХрд╛рд░ рдЧрдЯрд╛рд▓рд╛ рджреЗрдК:
рд╕реЗрдЯ-RDSPermissions.ps1
$Group = "RDP_Operators"
$Servers = @(
"RDSHost01",
"RDSHost02",
"RDSHost03"
)
ForEach ($Server in $Servers) {
#╨Ф╨╡╨╗╨╡╨│╨╕╤А╤Г╨╡╨╝ ╨┐╤А╨░╨▓╨╛ ╨╜╨░ ╤В╨╡╨╜╨╡╨▓╤Л╨╡ ╤Б╨╡╤Б╤Б╨╕╨╕
$WMIHandles = Get-WmiObject `
-Class "Win32_TSPermissionsSetting" `
-Namespace "rootCIMV2terminalservices" `
-ComputerName $Server `
-Authentication PacketPrivacy `
-Impersonation Impersonate
ForEach($WMIHandle in $WMIHandles)
{
If ($WMIHandle.TerminalName -eq "RDP-Tcp")
{
$retVal = $WMIHandle.AddAccount($Group, 2)
$opstatus = "╤Г╤Б╨┐╨╡╤И╨╜╨╛"
If ($retVal.ReturnValue -ne 0) {
$opstatus = "╨╛╤И╨╕╨▒╨║╨░"
}
Write-Host ("╨Ф╨╡╨╗╨╡╨│╨╕╤А╨╛╨▓╨░╨╜╨╕╨╡ ╨┐╤А╨░╨▓ ╨╜╨░ ╤В╨╡╨╜╨╡╨▓╨╛╨╡ ╨┐╨╛╨┤╨║╨╗╤О╤З╨╡╨╜╨╕╨╡ ╨│╤А╤Г╨┐╨┐╨╡ " +
$Group + " ╨╜╨░ ╤Б╨╡╤А╨▓╨╡╤А╨╡ " + $Server + ": " + $opstatus + "`r`n")
}
}
}
3 рдкрд╛рдКрд▓
рд╕реНрдерд╛рдирд┐рдХ рдЧрдЯрд╛рдд рдЧрдЯ рдЬреЛрдбрд╛ рджреВрд░рд╕реНрде рдбреЗрд╕реНрдХрдЯреЙрдк рд╡рд╛рдкрд░рдХрд░реНрддреЗ рдкреНрд░рддреНрдпреЗрдХ RDSH рд╕рд░реНрд╡реНрд╣рд░рд╡рд░. рддреБрдордЪреЗ рд╕рд░реНрд╡реНрд╣рд░ рд╕реЗрд╢рди рдХрд▓реЗрдХреНрд╢рдирдордзреНрдпреЗ рдПрдХрддреНрд░ рдХреЗрд▓реЗ рдЕрд╕рд▓реНрдпрд╛рд╕, рдЖрдореНрд╣реА рд╣реЗ рдХрд▓реЗрдХреНрд╢рди рд╕реНрддрд░рд╛рд╡рд░ рдХрд░рддреЛ:
$Group = "RDP_Operators"
$CollectionName = "MyRDSCollection"
[String[]]$CurrentCollectionGroups = @(Get-RDSessionCollectionConfiguration -CollectionName $CollectionName -UserGroup).UserGroup
Set-RDSessionCollectionConfiguration -CollectionName $CollectionName -UserGroup ($CurrentCollectionGroups + $Group)
рд╕рд┐рдВрдЧрд▓ рд╕рд░реНрд╡реНрд╣рд░рд╕рд╛рдареА рдЖрдореНрд╣реА рд╡рд╛рдкрд░рддреЛ
4 рдкрд╛рдКрд▓
рдЪрд▓рд╛ тАЬрд╡реНрдпрд╡рд╕реНрдерд╛рдкрдХтАЭ рд╕рд╛рдареА рдЦрд╛рд▓реАрд▓ PS рд╕реНрдХреНрд░рд┐рдкреНрдЯ рддрдпрд╛рд░ рдХрд░реВрдпрд╛:
RDSManagement.ps1
$Servers = @(
"RDSHost01",
"RDSHost02",
"RDSHost03"
)
function Invoke-RDPSessionLogoff {
Param(
[parameter(Mandatory=$True, Position=0)][String]$ComputerName,
[parameter(Mandatory=$true, Position=1)][String]$SessionID
)
$ErrorActionPreference = "Stop"
logoff $SessionID /server:$ComputerName /v 2>&1
}
function Invoke-RDPShadowSession {
Param(
[parameter(Mandatory=$True, Position=0)][String]$ComputerName,
[parameter(Mandatory=$true, Position=1)][String]$SessionID
)
$ErrorActionPreference = "Stop"
mstsc /shadow:$SessionID /v:$ComputerName /control 2>&1
}
Function Get-LoggedOnUser {
Param(
[parameter(Mandatory=$True, Position=0)][String]$ComputerName="localhost"
)
$ErrorActionPreference = "Stop"
Test-Connection $ComputerName -Count 1 | Out-Null
quser /server:$ComputerName 2>&1 | Select-Object -Skip 1 | ForEach-Object {
$CurrentLine = $_.Trim() -Replace "s+"," " -Split "s"
$HashProps = @{
UserName = $CurrentLine[0]
ComputerName = $ComputerName
}
If ($CurrentLine[2] -eq "Disc") {
$HashProps.SessionName = $null
$HashProps.Id = $CurrentLine[1]
$HashProps.State = $CurrentLine[2]
$HashProps.IdleTime = $CurrentLine[3]
$HashProps.LogonTime = $CurrentLine[4..6] -join " "
$HashProps.LogonTime = $CurrentLine[4..($CurrentLine.GetUpperBound(0))] -join " "
}
else {
$HashProps.SessionName = $CurrentLine[1]
$HashProps.Id = $CurrentLine[2]
$HashProps.State = $CurrentLine[3]
$HashProps.IdleTime = $CurrentLine[4]
$HashProps.LogonTime = $CurrentLine[5..($CurrentLine.GetUpperBound(0))] -join " "
}
New-Object -TypeName PSCustomObject -Property $HashProps |
Select-Object -Property UserName, ComputerName, SessionName, Id, State, IdleTime, LogonTime
}
}
$UserLogin = Read-Host -Prompt "╨Т╨▓╨╡╨┤╨╕╤В╨╡ ╨╗╨╛╨│╨╕╨╜ ╨┐╨╛╨╗╤М╨╖╨╛╨▓╨░╤В╨╡╨╗╤П"
Write-Host "╨Я╨╛╨╕╤Б╨║ RDP-╤Б╨╡╤Б╤Б╨╕╨╣ ╨┐╨╛╨╗╤М╨╖╨╛╨▓╨░╤В╨╡╨╗╤П ╨╜╨░ ╤Б╨╡╤А╨▓╨╡╤А╨░╤Е..."
$SessionList = @()
ForEach ($Server in $Servers) {
$TargetSession = $null
Write-Host " ╨Ю╨┐╤А╨╛╤Б ╤Б╨╡╤А╨▓╨╡╤А╨░ $Server"
Try {
$TargetSession = Get-LoggedOnUser -ComputerName $Server | Where-Object {$_.UserName -eq $UserLogin}
}
Catch {
Write-Host "╨Ю╤И╨╕╨▒╨║╨░: " $Error[0].Exception.Message -ForegroundColor Red
Continue
}
If ($TargetSession) {
Write-Host " ╨Э╨░╨╣╨┤╨╡╨╜╨░ ╤Б╨╡╤Б╤Б╨╕╤П ╤Б ID $($TargetSession.ID) ╨╜╨░ ╤Б╨╡╤А╨▓╨╡╤А╨╡ $Server" -ForegroundColor Yellow
Write-Host " ╨з╤В╨╛ ╨▒╤Г╨┤╨╡╨╝ ╨┤╨╡╨╗╨░╤В╤М?"
Write-Host " 1 - ╨┐╨╛╨┤╨║╨╗╤О╤З╨╕╤В╤М╤Б╤П ╨║ ╤Б╨╡╤Б╤Б╨╕╨╕"
Write-Host " 2 - ╨╖╨░╨▓╨╡╤А╤И╨╕╤В╤М ╤Б╨╡╤Б╤Б╨╕╤О"
Write-Host " 0 - ╨╜╨╕╤З╨╡╨│╨╛"
$Action = Read-Host -Prompt "╨Т╨▓╨╡╨┤╨╕╤В╨╡ ╨┤╨╡╨╣╤Б╤В╨▓╨╕╨╡"
If ($Action -eq "1") {
Invoke-RDPShadowSession -ComputerName $Server -SessionID $TargetSession.ID
}
ElseIf ($Action -eq "2") {
Invoke-RDPSessionLogoff -ComputerName $Server -SessionID $TargetSession.ID
}
Break
}
Else {
Write-Host " ╤Б╨╡╤Б╤Б╨╕╨╣ ╨╜╨╡ ╨╜╨░╨╣╨┤╨╡╨╜╨╛"
}
}
PS рд╕реНрдХреНрд░рд┐рдкреНрдЯ рдЪрд╛рд▓рд╡рдгреНрдпрд╛рд╕ рд╕реЛрдпреАрд╕реНрдХрд░ рдмрдирд╡рдгреНрдпрд╛рд╕рд╛рдареА, рдЖрдореНрд╣реА PS рд╕реНрдХреНрд░рд┐рдкреНрдЯ рдкреНрд░рдорд╛рдгреЗрдЪ рдирд╛рд╡ рдЕрд╕рд▓реЗрд▓реНрдпрд╛ cmd рдлрд╛рдИрд▓рдЪреНрдпрд╛ рд╕реНрд╡рд░реВрдкрд╛рдд рдПрдХ рд╢реЗрд▓ рддрдпрд╛рд░ рдХрд░реВ:
RDSManagement.cmd
@ECHO OFF
powershell -NoLogo -ExecutionPolicy Bypass -File "%~d0%~p0%~n0.ps1" %*
рдЖрдореНрд╣реА рджреЛрдиреНрд╣реА рдлрд╛рдпрд▓реА рдПрдХрд╛ рдлреЛрд▓реНрдбрд░рдордзреНрдпреЗ рдареЗрд╡рддреЛ рдЬреНрдпрд╛рдордзреНрдпреЗ "рд╡реНрдпрд╡рд╕реНрдерд╛рдкрдХ" рдкреНрд░рд╡реЗрд╢ рдХрд░рдгреНрдпрд╛рдпреЛрдЧреНрдп рдЕрд╕рддреАрд▓ рдЖрдгрд┐ рддреНрдпрд╛рдВрдирд╛ рдкреБрдиреНрд╣рд╛ рд▓реЙрдЧрд┐рди рдХрд░рдгреНрдпрд╛рд╕ рд╕рд╛рдВрдЧреВ. рдЖрддрд╛, cmd рдлрд╛рдЗрд▓ рдЪрд╛рд▓рд╡реВрди, рддреЗ RDS рд╢реЕрдбреЛ рдореЛрдбрдордзреАрд▓ рдЗрддрд░ рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдВрдЪреНрдпрд╛ рд╕рддреНрд░рд╛рдВрд╢реА рдХрдиреЗрдХреНрдЯ рдХрд░рдгреНрдпрд╛рдд рд╕рдХреНрд╖рдо рд╣реЛрддреАрд▓ рдЖрдгрд┐ рддреНрдпрд╛рдВрдирд╛ рд▓реЙрдЧ рдЖрдЙрдЯ рдХрд░рдгреНрдпрд╛рд╕ рднрд╛рдЧ рдкрд╛рдбреВ рд╢рдХрддреАрд▓ (рдЬреЗрд╡реНрд╣рд╛ рд╡рд╛рдкрд░рдХрд░реНрддрд╛ рд╕реНрд╡рддрдВрддреНрд░рдкрдгреЗ "рд╣рдБрдЧрд┐рдВрдЧ" рд╕рддреНрд░ рд╕рдорд╛рдкреНрдд рдХрд░реВ рд╢рдХрдд рдирд╛рд╣реА рддреЗрд╡реНрд╣рд╛ рд╣реЗ рдЙрдкрдпреБрдХреНрдд рдард░реВ рд╢рдХрддреЗ).
рд╣реЗ рдЕрд╕реЗ рдХрд╛рд╣реАрддрд░реА рджрд┐рд╕рддреЗ:
"рд╡реНрдпрд╡рд╕реНрдерд╛рдкрдХ" рд╕рд╛рдареА
рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рд╕рд╛рдареА
рдХрд╛рд╣реА рдЕрдВрддрд┐рдо рдЯрд┐рдкреНрдкрдгреНрдпрд╛
рд╕реВрдХреНрд╖реНрдорддрд╛ рез. рдЖрдореНрд╣реА рдЬреНрдпрд╛ рд╡рд╛рдкрд░рдХрд░реНрддрд╛ рд╕рддреНрд░рд╛рд╡рд░ рдирд┐рдпрдВрддреНрд░рдг рдорд┐рд│рд╡рдгреНрдпрд╛рдЪрд╛ рдкреНрд░рдпрддреНрди рдХрд░рдд рдЖрд╣реЛрдд рддреЗ Set-RDSPermissions.ps1 рд╕реНрдХреНрд░рд┐рдкреНрдЯ рд╕рд░реНрд╡реНрд╣рд░рд╡рд░ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рд┐рдд рд╣реЛрдгреНрдпрд╛рдкреВрд░реНрд╡реА рд▓реЙрдиреНрдЪ рдХреЗрд▓реЗ рдЕрд╕рд▓реНрдпрд╛рд╕, "рд╡реНрдпрд╡рд╕реНрдерд╛рдкрдХ" рд▓рд╛ рдкреНрд░рд╡реЗрд╢ рддреНрд░реБрдЯреА рдкреНрд░рд╛рдкреНрдд рд╣реЛрдИрд▓. рдпреЗрдереЗ рдЙрдкрд╛рдп рд╕реНрдкрд╖реНрдЯ рдЖрд╣реЗ: рд╡реНрдпрд╡рд╕реНрдерд╛рдкрд┐рдд рд╡рд╛рдкрд░рдХрд░реНрддрд╛ рд▓реЙрдЧ рдЗрди рд╣реЛрдИрдкрд░реНрдпрдВрдд рдкреНрд░рддреАрдХреНрд╖рд╛ рдХрд░рд╛.
рд╕реВрдХреНрд╖реНрдорддрд╛ рез. рдЖрд░рдбреАрдкреА рд╢реЕрдбреЛрд╕рд╣ рдЕрдиреЗрдХ рджрд┐рд╡рд╕ рдХрд╛рдо рдХреЗрд▓реНрдпрд╛рдирдВрддрд░, рдЖрдореНрд╣рд╛рд▓рд╛ рдПрдХ рдордиреЛрд░рдВрдЬрдХ рдмрдЧ рдХрд┐рдВрд╡рд╛ рд╡реИрд╢рд┐рд╖реНрдЯреНрдп рд▓рдХреНрд╖рд╛рдд рдЖрд▓реЗ: рд╢реЕрдбреЛ рд╕рддреНрд░рд╛рдЪреНрдпрд╛ рд╕рдорд╛рдкреНрддреАрдирдВрддрд░, рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдЪреНрдпрд╛ рдХрдиреЗрдХреНрдЯ рдХреЗрд▓реЗрд▓реНрдпрд╛ рдЯреНрд░реЗрдордзреАрд▓ рднрд╛рд╖рд╛ рдкрдЯреНрдЯреА рдЕрджреГрд╢реНрдп рд╣реЛрддреЗ рдЖрдгрд┐ рддреА рдкрд░рдд рдорд┐рд│рд╡рд┐рдгреНрдпрд╛рд╕рд╛рдареА, рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдиреЗ рдкреБрдиреНрд╣рд╛ рдХрд░рдгреЗ рдЖрд╡рд╢реНрдпрдХ рдЖрд╣реЗ. -рд▓реЙрдЧрд┐рди. рд╣реЗ рджрд┐рд╕реВрди рдпреЗрддреЗ рдХреА рдЖрдореНрд╣реА рдПрдХрдЯреЗ рдирд╛рд╣реА:
рдЗрддрдХрдВрдЪ. рдореА рддреБрдореНрд╣рд╛рд▓рд╛ рдЖрдгрд┐ рддреБрдордЪреНрдпрд╛ рд╕рд░реНрд╡реНрд╣рд░рд▓рд╛ рдЙрддреНрддрдо рдЖрд░реЛрдЧреНрдпрд╛рд╕рд╛рдареА рд╢реБрднреЗрдЪреНрдЫрд╛ рджреЗрддреЛ. рдиреЗрд╣рдореАрдкреНрд░рдорд╛рдгреЗ, рдореА рдЯрд┐рдкреНрдкрдгреНрдпрд╛рдВрдордзреАрд▓ рддреБрдордЪреНрдпрд╛ рдЕрднрд┐рдкреНрд░рд╛рдпрд╛рдЪреА рд╡рд╛рдЯ рдкрд╛рд╣рддреЛ рдЖрдгрд┐ рддреБрдореНрд╣рд╛рд▓рд╛ рдЦрд╛рд▓реАрд▓ рд▓рд╣рд╛рди рд╕рд░реНрд╡реЗрдХреНрд╖рдгрд╛рдд рд╕рд╣рднрд╛рдЧреА рд╣реЛрдгреНрдпрд╛рд╕ рд╕рд╛рдВрдЧрддреЛ.
рд╕реНрддреНрд░реЛрдд
RDS рд╕рд╛рд╡рд▓реА - рд╡рд┐рдВрдбреЛрдЬ рд╕рд░реНрд╡реНрд╣рд░ 2016 / 2012 R2 рдордзреАрд▓ RDP рд╡рд╛рдкрд░рдХрд░реНрддрд╛ рд╕рддреНрд░рд╛рдВрд╕рд╛рдареА рдЫрд╛рдпрд╛ рдХрдиреЗрдХреНрд╢рди Windows Server 2012 Shadowing тАУ рдЧреИрд░-рдкреНрд░рд╢рд╛рд╕рдХрд╛рдВрдирд╛ рдЕрдзрд┐рдХрд╛рд░ рд╕реЛрдкрд╡рдгреЗ Get-LoggedOnUser рд░рд┐рдореЛрдЯ рд╕рд┐рд╕реНрдЯреАрдорд╡рд░ рд▓реЙрдЧ рдСрди рдХреЗрд▓реЗрд▓реНрдпрд╛ рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдВрдЪреА рдорд╛рд╣рд┐рддреА рдЧреЛрд│рд╛ рдХрд░рддреЗ PowerShell PS1 рд╕реНрдХреНрд░рд┐рдкреНрдЯреНрд╕ рдХрд╢реА рд╕реБрд░реВ рдХрд░рд╛рдпрдЪреА рд╣рд╛ рд╕рд░реНрд╡реЛрддреНрддрдо рдорд╛рд░реНрдЧ рдЖрд╣реЗ рд╕реНрдерд╛рдирд┐рдХ рд╕реБрд░рдХреНрд╖рд╛ рдЧрдЯрд╛рдд рдбреЛрдореЗрди рд╡рд╛рдкрд░рдХрд░реНрддреЗ рдЬреЛрдбрдд рдЖрд╣реЗ GPMC - OU рдордзреАрд▓ рд╕рд░реНрд╡ рд╕рдВрдЧрдгрдХрд╛рдВрд╡рд░ gpupdate рд╕рдХреНрддреА рдХрд░рд╛
рдХреЗрд╡рд│ рдиреЛрдВрджрдгреАрдХреГрдд рд╡рд╛рдкрд░рдХрд░реНрддреЗрдЪ рд╕рд░реНрд╡реЗрдХреНрд╖рдгрд╛рдд рднрд╛рдЧ рдШреЗрдК рд╢рдХрддрд╛рдд.
рддреБрдореНрд╣реА рдХрд╛рдп рд╡рд╛рдкрд░рддрд╛?
-
8,1%AMMYY Admin5
-
17,7%AnyDesk11
-
9,7%DameWare6
-
24,2%Radmin15
-
14,5%RDS рд╕рд╛рд╡рд▓реА9
-
1,6%рдХреНрд╡рд┐рдХ рдЕрд╕рд┐рд╕реНрдЯ / рд╡рд┐рдВрдбреЛрдЬ рд░рд┐рдореЛрдЯ рдЕрд╕рд┐рд╕реНрдЯрдиреНрд╕1
-
38,7%TeamViewer24
-
32,3%VNC20
-
32,3%рдЗрддрд░20
-
3,2%LiteManager2
62 рд╡рд╛рдкрд░рдХрд░реНрддреНрдпрд╛рдВрдиреА рдорддрджрд╛рди рдХреЗрд▓реЗ. 22 рд╡рд╛рдкрд░рдХрд░реНрддреЗ рджреВрд░ рд░рд╛рд╣рд┐рд▓реЗ.
рд╕реНрддреНрд░реЛрдд: www.habr.com