about_Remote_Disconnected_Sessions

Краткое описание

В этой статье объясняется, как отключить сеанс PowerShell (PSSession) и повторно подключиться к ней.

Подробное описание

Начиная с PowerShell 3.0, вы можете отключиться от psSession и повторно подключиться к psSession с того же или другого компьютера. Состояние сеанса сохраняется, а команды в PSSession продолжают выполняться, пока сеанс отключен.

Функция "Отключенные сеансы" позволяет закрыть сеанс, в котором был создан сеанс PSSession, и завершить работу компьютера, не нарушая выполнение команд в удаленном сеансе PSSession. Отключенные сеансы полезны для выполнения команд, выполнение которых занимает длительное время.

Вы не можете отключиться от интерактивного сеанса, запущенного с помощью командлета Enter-PSSession .

Отключенные сеансы можно использовать для управления сеансами PSSession, которые были непреднамеренно отключены в результате сбоя компьютера или сети.

Командлеты отключенного сеанса

Следующие командлеты поддерживают функцию отключенных сеансов:

  • Connect-PSSession: подключается к отключенной psSession.
  • Disconnect-PSSession: отключает PSSession.
  • Get-PSSession: получает psSessions на локальном компьютере или на удаленных компьютерах.
  • Receive-PSSession: возвращает результаты команд, которые выполнялись в отключенных сеансах.
  • Invoke-Command: параметр InDisconnectedSession создает psSession и немедленно отключается.

Принцип работы функции "Отключенные сеансы"

Начиная с PowerShell 3.0, psSessions не зависят от сеансов, в которых они созданы. Активные сеансы PSSessions поддерживаются на стороне удаленного компьютера или сервера подключения, даже если компьютер на стороне клиента выключен или отключен от сети.

В PowerShell 2.0 psSession удаляется с удаленного компьютера при отключении от исходного сеанса или сеанса, в котором он был создан, завершается.

При отключении PSSession psSession остается активным и поддерживается на удаленном компьютере. Состояние сеанса изменится с Выполняется на Отключено. Вы можете повторно подключиться к отключенной psSession из

  • Текущий сеанс на том же компьютере
  • Другой сеанс на том же компьютере
  • Из сеанса на другом компьютере

Удаленный компьютер, поддерживающий сеанс, должен быть запущен и подключен к сети.

Команды в отключенном сеансе PSSession продолжают выполняться непрерывно на удаленном компьютере, пока команда не завершится или не заполнится выходной буфер. Чтобы предотвратить приостановку команды полным буфером вывода, используйте параметр Disconnect-PSSessionOutputBufferingMode командлетов , New-PSSessionOptionили New-PSTransportOption .

Отключенные сеансы поддерживаются на удаленном компьютере в отключенном состоянии. Они доступны для повторного подключения, пока вы не удалите PSSession, например с помощью командлета Remove-PSSession , или до тех пор, пока не истечет время ожидания простоя PSSession. Время ожидания простоя psSession можно настроить с помощью параметров Disconnect-PSSessionIdleTimeoutSec или IdleTimeout командлетов , New-PSSessionOptionили New-PSTransportOption .

Другой пользователь может подключиться к созданным сеансам PSSessions, но только в том случае, если он может предоставить учетные данные, которые использовались для создания сеанса, или использовать учетные RunAs данные конфигурации сеанса.

Как получить PSSessions

Начиная с PowerShell 3.0, Get-PSSession командлет получает psSessions на локальном и удаленном компьютерах. Он также может получить PSSessions, созданные в текущем сеансе.

Чтобы получить psSessions на локальном компьютере или удаленных компьютерах, используйте параметры ComputerName или ConnectionUri . Без параметров Get-PSSession получает PSSession, созданные в локальном сеансе, независимо от того, где они завершаются.

В следующем примере показано, как использовать Get-PSSession.

New-PSSession создает сеанс для компьютера Server01. Сеанс находится на компьютере Server01.

New-PSSession -ComputerName Server01
Id Name      ComputerName  State    ConfigurationName     Availability
-- ----      ------------  -----    -----------------     ------------
 2 Session2  Server01      Opened   Microsoft.PowerShell     Available

Чтобы получить сеанс из Server01, используйте параметр ComputerName , чтобы указать целевой Get-PSSessionобъект .

Get-PSSession -ComputerName Server01
Id Name      ComputerName  State    ConfigurationName     Availability
-- ----      ------------  -----    -----------------     ------------
 2 Session2  Server01      Opened   Microsoft.PowerShell     Available

Если значение параметра Get-PSSessionComputerName для параметра равно localhost, Get-PSSession получает psSessions, которые завершаются в и сохраняются на локальном компьютере. Она не получает psSessions на компьютере Server01, даже если они были запущены на локальном компьютере.

Get-PSSession -ComputerName localhost

Чтобы получить сеансы, созданные в текущем сеансе Get-PSSession , используйте командлет без параметров. В этом примере получает psSession, Get-PSSession который был создан в текущем сеансе и подключается к компьютеру Server01.

Get-PSSession
Id Name      ComputerName  State    ConfigurationName     Availability
-- ----      ------------  -----    -----------------     ------------
 2 Session2  Server01      Opened   Microsoft.PowerShell     Available

Отключение сеансов

Disconnect-PSSession Используйте командлет , чтобы отключить сеанс. Чтобы определить psSession, используйте параметр Session или по конвейеру объекта PSSession из New-PSSession командлетов или Get-PSSession в .Disconnect-PSSession

Следующая команда отключает PSSession от компьютера Server01. Обратите внимание, что для свойства Stateзадано значение Disconnected , а для параметра AvailabilityНет.

Get-PSSession -ComputerName Server01 | Disconnect-PSSession
Id Name      ComputerName  State         ConfigurationName     Availability
-- ----      ------------  -----         -----------------     ------------
 2 Session2  Server01      Disconnected  Microsoft.PowerShell          None

Чтобы создать отключенный сеанс, используйте параметр InDisconnectedSession командлета Invoke-Command . Он создает сеанс, запускает команду и отключается немедленно, прежде чем команда может вернуть какие-либо выходные данные.

Следующая команда выполняет Get-WinEvent команду в отключенном сеансе на удаленном компьютере Server02.

Invoke-Command -ComputerName Server02 -InDisconnectedSession -ScriptBlock {
   Get-WinEvent -LogName "*PowerShell*" }
Id Name      ComputerName  State         ConfigurationName     Availability
-- ----      ------------  -----         -----------------     ------------
 4 Session3  Server02      Disconnected  Microsoft.PowerShell          None

Подключение к отключенным сеансам

Чтобы подключить отключенный сеанс, используйте Connect-PSSession командлет с параметрами ComputerName или ConnectionUri . Кроме того, можно передать выходные данные Get-PSSessionConnect-PSSessionв .

В следующем примере извлекается сеанс на компьютере Server02. Выходные данные включают два отключенных сеанса.

Get-PSSession -ComputerName Server02
Id Name      ComputerName   State         ConfigurationName     Availability
-- ----      ------------   -----         -----------------     ------------
 2 Session2  juneb-srv8320  Disconnected  Microsoft.PowerShell          None
 4 Session3  juneb-srv8320  Disconnected  Microsoft.PowerShell          None

Следующая команда подключается к Session2. PsSession теперь открыт и доступен.

Connect-PSSession -ComputerName Server02 -Name Session2
Id Name      ComputerName    State    ConfigurationName     Availability
-- ----      ------------    -----    -----------------     ------------
 2 Session2  juneb-srv8320   Opened   Microsoft.PowerShell     Available

Как получить результаты

Чтобы получить результаты команд, которые выполнялись в отключенном сеансе PSSession, используйте Receive-PSSession командлет .

Вместо командлета Connect-PSSession можно использовать Receive-PSSession . Если сеанс уже повторно подключен, получает результаты команд, Receive-PSSession которые выполнялись при отключении сеанса. Если PSSession по-прежнему отключен, Receive-PSSession подключается к нему, а затем получает результаты команд, которые выполнялись во время отключения.

Receive-PSSession может возвращать результаты в задании (асинхронно) или в ведущем приложении (синхронно). Используйте параметр OutTarget , чтобы выбрать Задание или Узел. Значение по умолчанию — Host. Однако если полученная команда была запущена в текущем сеансе как задание, она по умолчанию возвращается как задание .

В следующем примере командлет используется Receive-PSSession для повторного подключения к сеансу на сервере Server02 и получения результатов Get-WinEvent команды . Параметр OutTarget используется для получения результатов в задании.

Receive-PSSession -ComputerName Server02 -Name Session3 -OutTarget Job
Id   Name   PSJobTypeName   State         HasMoreData     Location
--   ----   -------------   -----         -----------     --------
 3   Job3   RemoteJob       Running       True            Server02

Чтобы получить результаты задания, используйте Receive-Job командлет .

Get-Job | Receive-Job -Keep
ProviderName: PowerShell

TimeCreated             Id LevelDisplayName Message     PSComputerName
-----------             -- ---------------- -------     --------------
5/14/2012 7:26:04 PM   400 Information      Engine stat Server02
5/14/2012 7:26:03 PM   600 Information      Provider "W Server02
5/14/2012 7:26:03 PM   600 Information      Provider "C Server02
5/14/2012 7:26:03 PM   600 Information      Provider "V Server02

Свойства состояния и доступности

Свойства Состояние и Доступность отключенного сеанса PSSession сообщают, доступен ли сеанс для повторного подключения к нему.

Когда PSSession подключен к текущему сеансу, его состояние — Открыто , а доступность — Доступна. При отключении от PSSession состояние PSSession имеет значение Отключено , а его доступность — Нет.

Значение свойства State определяется текущим сеансом. Значение Disconnected означает, что PSSession не подключен к текущему сеансу. Но это не означает, что PSSession отключен от всех сеансов. Он может быть подключен к другому сеансу.

Чтобы определить, можно ли подключиться или повторно подключиться к PSSession, используйте свойство Availability . Значение None указывает, что вы можете подключиться к сеансу. Значение Busy указывает, что вы не можете подключиться к PSSession, так как оно подключено к другому сеансу.

Следующий пример выполняется в двух сеансах PowerShell на одном компьютере. Обратите внимание на изменение значений свойств State и Availability в каждом сеансе, так как PSSession отключается и повторно подключается.

# Session 1
New-PSSession -ComputerName Server30 -Name Test
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
1  Test   Server30        Opened        Microsoft.PowerShell     Available
# Session 2
Get-PSSession -ComputerName Server30 -Name Test
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
1 Test    Server30        Disconnected  Microsoft.PowerShell          Busy
# Session 1
Get-PSSession -ComputerName Server30 -Name Test | Disconnect-PSSession
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
1 Test    Server30        Disconnected  Microsoft.PowerShell          None
# Session 2
Get-PSSession -ComputerName Server30
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
1 Test    Server30        Disconnected  Microsoft.PowerShell          None
# Session 2
Connect-PSSession -ComputerName Server30 -Name Test
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
3 Test    Server30        Opened        Microsoft.PowerShell     Available
# Session 1
Get-PSSession -ComputerName Server30
Id Name   ComputerName    State         ConfigurationName     Availability
-- ----   ------------    -----         -----------------     ------------
1 Test    Server30        Disconnected  Microsoft.PowerShell          Busy

Отключенные сеансы сохраняются на удаленном компьютере до тех пор, пока вы не удалите их, например с помощью командлета Remove-PSSession , или до истечения времени ожидания. Свойство IdleTimeout psSession определяет, как долго будет поддерживаться отключенный сеанс перед удалением.

Значения времени ожидания простоя

Сеансы PSSessions простаивают, когда поток пульса не получает ответа. Отключение сеанса делает его бездействующим и запускает часы IdleTimeout , даже если команды по-прежнему выполняются в отключенном сеансе. PowerShell считает отключенные сеансы активными, но бездействуют.

При создании и отключении сеансов убедитесь, что время ожидания простоя в PSSession достаточно длительное, чтобы поддерживать сеанс в соответствии с вашими потребностями, но не так долго, чтобы он потреблял ненужные ресурсы на удаленном компьютере.

Свойство IdleTimeoutMs конфигурации сеанса определяет время ожидания простоя по умолчанию для сеансов, использующих конфигурацию сеанса. Вы можете переопределить значение по умолчанию, но это значение не может превышать свойство MaxIdleTimeoutMs конфигурации сеанса.

Используйте следующую команду, чтобы получить значения IdleTimeoutMs и MaxIdleTimeoutMs для конфигурации сеанса.

Get-PSSessionConfiguration |
  Format-Table Name, IdleTimeoutMs, MaxIdleTimeoutMs

Если вы являетесь членом группы администраторов на удаленном компьютере, эти значения можно задать при создании конфигурации сеанса. Кроме того, вы можете изменить значения при отключении.

Время ожидания простоя для конфигураций сеанса и параметров сеанса составляет миллисекунд. Значение времени ожидания простоя сеансов и параметров конфигурации сеансов составляет в секундах.

Время ожидания простоя psSession можно задать при создании PSSession (New-PSSession, Invoke-Command) и при отключении от него (Disconnect-PSSession). Однако вы не можете изменить значение IdleTimeout при подключении к PSSession (Connect-PSSession) или получении результатов (Receive-PSSession).

Командлеты Connect-PSSession и Receive-PSSession имеют параметр SessionOption , который принимает объект PSSessionOption , например объект , возвращаемый командлетом New-PSSessionOption .

Значение IdleTimeout в объекте SessionOption и значение IdleTimeout в $PSSessionOption переменной предпочтения не изменяют значение IdleTimeout в команде Connect-PSSession или Receive-PSSession .

Чтобы создать PSSession с определенным значением времени ожидания простоя, создайте переменную $PSSessionOption предпочтения. Задайте для свойства IdleTimeout требуемое значение (в миллисекундах).

При создании PSSessions значения в $PSSessionOption переменной имеют приоритет над значениями в конфигурации сеанса.

Например, следующая команда устанавливает время ожидания простоя в 48 часов:

$PSSessionOption = New-PSSessionOption -IdleTimeoutMSec 172800000

Чтобы создать PSSession с определенным значением времени ожидания простоя, используйте параметр IdleTimeoutMSec командлета New-PSSessionOption . Затем используйте параметр сеанса в значении параметра New-PSSessionSessionOption командлетов или Invoke-Command .

Значения, заданные при создании сеанса, имеют приоритет над значениями, заданными в переменной $PSSessionOption предпочтения и конфигурации сеанса.

Пример:

$o = New-PSSessionOption -IdleTimeoutMSec 172800000
New-PSSession -SessionOption $o

Чтобы изменить время ожидания простоя PSSession при отключении, используйте параметр IdleTimeoutSec командлета Disconnect-PSSession .

Пример:

Disconnect-PSSession -IdleTimeoutSec 172800

Чтобы создать конфигурацию сеанса с определенным временем ожидания простоя и максимальным временем ожидания простоя, используйте параметры IdleTimeoutSec и MaxIdleTimeoutSec командлета New-PSTransportOption . Затем используйте параметр transport в значении параметра TransportOption объекта Register-PSSessionConfiguration.

Пример:

$o = New-PSTransportOption -IdleTimeoutSec 172800 -MaxIdleTimeoutSec 259200
Register-PSSessionConfiguration -Name Test -TransportOption $o

Чтобы изменить время ожидания простоя по умолчанию и максимальное время ожидания простоя для конфигурации сеанса, используйте параметры IdleTimeoutSec и MaxIdleTimeoutSec командлета New-PSTransportOption . Затем используйте параметр transport в значении параметра TransportOption объекта Set-PSSessionConfiguration.

Пример:

$o = New-PSTransportOption -IdleTimeoutSec 172800 -MaxIdleTimeoutSec 259200
Set-PSSessionConfiguration -Name Test -TransportOption $o

Режим буферизации выходных данных

Режим буферизации выходных данных PSSession определяет способ управления выходными данными команд при заполнении выходного буфера PSSession.

В отключенном сеансе режим буферизации выходных данных фактически определяет, продолжает ли команда выполняться во время отключения сеанса.

Допустимые значения:

  • Block (по умолчанию) — когда выходной буфер заполнен, выполнение приостанавливается до тех пор, пока буфер не будет очищен. Block сохраняет данные, но может прервать выполнение команды.
  • Drop — Когда выходной буфер заполнен, выполнение продолжается. При создании новых выходных данных самые старые выходные данные удаляются. При использовании Drop значения перенаправьте выходные данные в файл. Это значение рекомендуется для отключенных сеансов.

Свойство OutputBufferingMode конфигурации сеанса определяет режим буферизации по умолчанию для сеансов, использующих конфигурацию сеанса.

Чтобы найти значение outputBufferingMode в конфигурации сеанса, можно использовать любой из следующих форматов команд:

(Get-PSSessionConfiguration <ConfigurationName>).OutputBufferingMode
Get-PSSessionConfiguration | Format-Table Name, OutputBufferingMode

Вы можете переопределить значение по умолчанию в конфигурации сеанса и задать режим буферизации вывода psSession при создании PSSession, при отключении и при повторном подключении.

Если вы являетесь членом группы администраторов на удаленном компьютере, вы можете создать и изменить режим буферизации выходных данных конфигураций сеанса.

Чтобы создать PSSession с режимом буферизации выходных Dropданных , создайте переменную $PSSessionOption предпочтения, в которой значение свойства OutputBufferingMode равно Drop.

При создании PSSessions значения в $PSSessionOption переменной имеют приоритет над значениями в конфигурации сеанса.

Пример:

$PSSessionOption = New-PSSessionOption -OutputBufferingMode Drop

Используйте параметр OutputBufferingMode командлета New-PSSessionOption , чтобы создать параметр сеанса со значением Drop. Затем используйте объект PSSessionOption в качестве значения параметра New-PSSessionSessionOption командлетов или Invoke-Command .

Значения, заданные при создании сеанса, имеют приоритет над значениями, заданными в переменной $PSSessionOption предпочтения и конфигурации сеанса.

Пример:

$o = New-PSSessionOption -OutputBufferingMode Drop
New-PSSession -SessionOption $o

Чтобы изменить режим буферизации выходных данных PSSession при отключении, используйте параметр OutputBufferingMode командлета Disconnect-PSSession .

Пример:

Disconnect-PSSession -OutputBufferingMode Drop

Чтобы изменить режим буферизации выходных данных PSSession при повторном подключении, используйте параметр OutputBufferingMode командлета New-PSSessionOption . Затем используйте параметр сеанса в значении параметра SessionOption или Connect-PSSessionReceive-PSSession.

Пример:

$o = New-PSSessionOption -OutputBufferingMode Drop
Connect-PSSession -ComputerName Server01 -Name Test -SessionOption $o

Чтобы создать конфигурацию сеанса с режимом буферизации выходных Dropданных по умолчанию , используйте параметр OutputBufferingMode командлета New-PSTransportOption для создания объекта параметра транспорта со значением Drop. Затем используйте параметр transport в значении параметра TransportOption объекта Register-PSSessionConfiguration.

Пример:

$o = New-PSTransportOption -OutputBufferingMode Drop
Register-PSSessionConfiguration -Name Test -TransportOption $o

Чтобы изменить режим буферизации выходных данных по умолчанию для конфигурации сеанса, используйте параметр OutputBufferingMode командлета New-PSTransportOption для создания параметра транспорта со значением Drop. Затем используйте параметр Транспорт в значении параметра SessionOption объекта Set-PSSessionConfiguration.

Пример:

$o = New-PSTransportOption -OutputBufferingMode Drop
Set-PSSessionConfiguration -Name Test -TransportOption $o

Отключение сеансов замыкания на себя

Сеансы замыкания на себя (локальные сеансы) — это сеансы PSSessions, которые создаются и завершаются на том же компьютере. Как и другие сеансы PSSessions, активные сеансы замыкания на себя поддерживаются на компьютере на удаленном конце подключения (локальном компьютере), поэтому вы можете отключиться от сеансов замыкания на себя и повторно подключиться к сеансам замыкания на себя.

По умолчанию сеансы замыкания на себя создаются с помощью маркера безопасности сети, который не позволяет выполнять команды в сеансе для доступа к другим компьютерам. Вы можете повторно подключиться к сеансам замыкания на себя, имеющим маркер безопасности сети, из любого сеанса на локальном или удаленном компьютере.

Однако при использовании параметра EnableNetworkAccess командлета New-PSSession, Enter-PSSessionили Invoke-Command сеанс замыкания на себя создается с интерактивным маркером безопасности. Интерактивный маркер позволяет командам, выполняемым в сеансе замыкания на себя, получать данные с других компьютеров.

Вы можете отключить сеансы замыкания на себя с помощью интерактивных маркеров, а затем повторно подключиться к ним из того же или другого сеанса на том же компьютере. Однако для предотвращения вредоносного доступа можно повторно подключаться к сеансам замыкания на себя с интерактивными маркерами только с компьютера, на котором они были созданы.

Ожидание заданий в отключенных сеансах

Командлет Wait-Job ожидает завершения задания, а затем возвращается в командную строку или следующую команду. По умолчанию возвращает значение , если сеанс, Wait-Job в котором выполняется задание, отключен. Чтобы направить Wait-Job командлет на ожидание повторного подключения сеанса, в состоянии "Открыто" используйте параметр Force . Дополнительные сведения см. в разделе Wait-Job.

Надежные сеансы и непреднамеренное отключение

PsSession может быть непреднамеренно отключен из-за сбоя компьютера или сбоя сети. PowerShell пытается восстановить PSSession, но его успех зависит от серьезности и длительности причины.

Состояние непреднамеренно отключенного psSession может быть сломанным или закрытым, но оно также может быть отключено. Если для параметра Stateзадано значение Disconnected, можно использовать те же методы для управления PSSession, что и при намеренном отключении сеанса. Например, можно использовать командлет для повторного Connect-PSSession подключения к сеансу Receive-PSSession , а командлет — для получения результатов команд, которые выполнялись во время отключения сеанса.

Если закрыть (выйти) сеанс, в котором был создан PSSession во время выполнения команд в PSSession, PowerShell сохранит psSession в состоянии "Отключено" на удаленном компьютере. Если закрыть (выйти) сеанс, в котором было создано psSession, но в PSSession не выполняются команды, PowerShell не будет пытаться поддерживать PSSession.

См. также раздел