Получает сеансы Windows PowerShell (объекты PSSession) в текущем сеансе.
Синтаксис
Get-PSSession [[-ComputerName] <string[]>] [<CommonParameters>] Get-PSSession [-Id] <Int32[]> [<CommonParameters>] Get-PSSession [-InstanceId <Guid[]>] [<CommonParameters>] Get-PSSession [-Name <string[]>] [<CommonParameters>]
Описание
Командлет Get-PSSession получает сеансы Windows PowerShell (объекты PSSession), созданные в текущем сеансе.
При вызове без параметров команда "Get-PSSession" получает все объекты PSSession, созданные в текущем сеансе. Параметры Get-PSSession можно использовать для получения сеансов, связанных с определенными компьютерами, или определения сеансов по их именам, идентификаторам или идентификаторам экземпляров.
Дополнительные сведения о сеансах Windows PowerShell см. в разделе "about_PSSessions".
Параметры
-ComputerName <string[]>
Получает только сеансы PSSession, связанные с указанными компьютерами. Подстановочные знаки разрешены.
Введите имя NetBIOS, IP-адрес или полное доменное имя одного или нескольких компьютеров. Чтобы указать локальный компьютер, введите имя компьютера, "localhost" или точку (.).
Обязательно? |
false |
Позиция? |
1 |
Значение по умолчанию |
|
Принимать входные данные из конвейера? |
true (ByPropertyName) |
Принимать подстановочные знаки? |
true |
-Id <Int32[]>
Получает только сеансы PSSession с указанными идентификаторами. Введите один или несколько идентификаторов (разделенных запятыми) или используйте оператор диапазона (..), чтобы задать диапазон идентификаторов.
Идентификатор — это целое значение, которое однозначно определяет сеанс PSSession в пределах текущего сеанса. Это значение проще запомнить и ввести, чем InstanceId, но оно уникально только в рамках текущего сеанса. Чтобы определить идентификатор сеанса PSSession, используйте команду Get-PSSession без параметров.
Обязательно? |
true |
Позиция? |
1 |
Значение по умолчанию |
All sessions in the shell |
Принимать входные данные из конвейера? |
true (ByPropertyName) |
Принимать подстановочные знаки? |
false |
-InstanceId <Guid[]>
Получает только сеансы PSSession с указанными идентификаторами экземпляров.
Идентификатор экземпляра — это GUID, который однозначно определяет сеанс PSSession на локальном или удаленном компьютере. Идентификатор InstanceID является уникальным даже при выполнении нескольких сеансов Windows PowerShell.
Идентификатор экземпляра InstanceID хранится в свойстве InstanceID объекта, представляющего сеанс PSSession. Чтобы определить идентификаторы экземпляров InstanceID сеансов PSSession в текущем сеансе, введите команду "get-pssession | Format-Table Name, ComputerName, InstanceId".
Обязательно? |
false |
Позиция? |
named |
Значение по умолчанию |
|
Принимать входные данные из конвейера? |
true (ByPropertyName) |
Принимать подстановочные знаки? |
true |
-Name <string[]>
Получает только сеансы PSSession с указанными понятными именами. Подстановочные знаки разрешены.
Чтобы определить имена сеансов PSSession в текущем сеансе, введите команду "get-pssession" без параметров.
Обязательно? |
false |
Позиция? |
named |
Значение по умолчанию |
|
Принимать входные данные из конвейера? |
true (ByPropertyName) |
Принимать подстановочные знаки? |
true |
<CommonParameters>
Данный командлет поддерживает общие параметры -Verbose, -Debug, -ErrorAction, -ErrorVariable, -OutBuffer и -OutVariable. Дополнительные сведения см. в разделе about_Commonparameters.
Ввод и вывод
Входным типом является тип объектов, которые можно передавать командлету по конвейеру. Возвращаемым типом является тип объектов, возвращаемых командлетом.
Входные данные |
None Передать входные данные этому командлету по конвейеру невозможно. |
Выходные данные |
System.Management.Automation.Runspaces.PSSession Командлет Get-PSSession возвращает объект PSSession для каждого получаемого сеанса PSSession. |
Примечания
Команда Get-PSSession получает объекты PSSession, созданные в текущем сеансе. Она не получает сеансы, которые были созданы при запуске Windows PowerShell, и не получает объекты PSSession для сеансов, которые были созданы в других сеансах или на других компьютерах, даже если они подключены к локальному компьютеру.
Пример 1
C:\PS>get-pssession Description ----------- Эта команда получает все объекты PSSession, созданные в текущем сеансе. Она не получает объекты PSSession, которые были созданы в других сеансах или на других компьютерах, даже если они подключены к этому компьютеру.
Пример 2
C:\PS>$s = get-pssession -computername Server02 Description ----------- Эта команда получает объекты PSSession, которые связаны с компьютером Server02 и сохраняет их в переменной $p.
Пример 3
C:\PS>new-pssession -computername Server01, Server02, Server03 C:\PS> $s1, $s2, $s3 = get-pssession Description ----------- В этом примере показано, как сохранить результаты выполнения команды Get-PSSession в нескольких переменных. Первая команда создает сеансы PSSession на трех удаленных компьютерах с использованием командлета New-PSSession. Вторая команда использует командлет Get-PSSession для получения трех объектов PSSession. Затем каждый из сеансов PSSession сохраняется в отдельную переменную. Когда Windows PowerShell присваивает массив объектов массиву переменных, первый объект присваивается первой переменной, второй объект присваивается второй переменной и т. д. Если количество объектов превосходит количество переменных, все оставшиеся объекты присваиваются последней переменной в форме массива. Если количество переменных превышает количество объектов, лишние переменные не используются.
Пример 4
C:\PS>get-pssession | format-table -property computername, InstanceID C:\PS> $s = get-pssession -InstanceID a786be29-a6bb-40da-80fb-782c67f7db0f C:\PS> remove-pssession -session $s Description ----------- В этом примере показано, как получить сеанс PSSession с использованием идентификатора экземпляра, и затем удалить сеанс PSSession. Первая команда получает все сеансы PSSession на локальном компьютере. Она отправляет сеансы PSSession командлету Format-Table, который отображает значения свойств ComputerName и InstanceID для каждого из сеансов PSSession. Вторая команда использует командлет Get-PSSession для получения определенного сеанса PSSession и сохраняет его в переменной $s. Эта команда использует параметр InstanceID для определения сеанса PSSession. Третья команда использует командлет Remove-PSSession для удаления сеанса PSSession, сохраненного в переменной $s.
Пример 5
C:\PS>get-pssession -computername Serv* Description ----------- Эта команда получает все сеансы PSSession, связанные с компьютерами, имена которых начинаются на "Serv".
Пример 6
C:\PS>get-pssession -name Test*, Ux* Description ----------- Эта команда возвращает сеансы PSSession, имена которых начинаются на "Test" или "Ux".
Пример 7
C:\PS>get-pssession 2 Description ----------- Эта команда получает сеанс PSSession с идентификатором, равным 2.