Get-PSSession

获取本地和远程计算机上的 PowerShell 会话。

语法

Get-PSSession
   [-Name <String[]>]
   [<CommonParameters>]
Get-PSSession
   [-ComputerName] <String[]>
   [-ApplicationName <String>]
   [-ConfigurationName <String>]
   [-Name <String[]>]
   [-Credential <PSCredential>]
   [-Authentication <AuthenticationMechanism>]
   [-CertificateThumbprint <String>]
   [-Port <Int32>]
   [-UseSSL]
   [-ThrottleLimit <Int32>]
   [-State <SessionFilterState>]
   [-SessionOption <PSSessionOption>]
   [<CommonParameters>]
Get-PSSession
   [-ComputerName] <String[]>
   [-ApplicationName <String>]
   [-ConfigurationName <String>]
   -InstanceId <Guid[]>
   [-Credential <PSCredential>]
   [-Authentication <AuthenticationMechanism>]
   [-CertificateThumbprint <String>]
   [-Port <Int32>]
   [-UseSSL]
   [-ThrottleLimit <Int32>]
   [-State <SessionFilterState>]
   [-SessionOption <PSSessionOption>]
   [<CommonParameters>]
Get-PSSession
   [-ConnectionUri] <Uri[]>
   [-ConfigurationName <String>]
   [-AllowRedirection]
   [-Name <String[]>]
   [-Credential <PSCredential>]
   [-Authentication <AuthenticationMechanism>]
   [-CertificateThumbprint <String>]
   [-ThrottleLimit <Int32>]
   [-State <SessionFilterState>]
   [-SessionOption <PSSessionOption>]
   [<CommonParameters>]
Get-PSSession
   [-ConnectionUri] <Uri[]>
   [-ConfigurationName <String>]
   [-AllowRedirection]
   -InstanceId <Guid[]>
   [-Credential <PSCredential>]
   [-Authentication <AuthenticationMechanism>]
   [-CertificateThumbprint <String>]
   [-ThrottleLimit <Int32>]
   [-State <SessionFilterState>]
   [-SessionOption <PSSessionOption>]
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   -InstanceId <Guid[]>
   [-State <SessionFilterState>]
   -VMName <String[]>
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   [-Name <String[]>]
   [-State <SessionFilterState>]
   -ContainerId <String[]>
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   -InstanceId <Guid[]>
   [-State <SessionFilterState>]
   -ContainerId <String[]>
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   [-Name <String[]>]
   [-State <SessionFilterState>]
   -VMId <Guid[]>
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   -InstanceId <Guid[]>
   [-State <SessionFilterState>]
   -VMId <Guid[]>
   [<CommonParameters>]
Get-PSSession
   [-ConfigurationName <String>]
   [-Name <String[]>]
   [-State <SessionFilterState>]
   -VMName <String[]>
   [<CommonParameters>]
Get-PSSession
   [-InstanceId <Guid[]>]
   [<CommonParameters>]
Get-PSSession
   [-Id] <Int32[]>
   [<CommonParameters>]

说明

Get-PSSession cmdlet 获取本地和远程计算机上用户托管的 PowerShell 会话(Pssession)。

从 Windows PowerShell 3.0 开始,会话将存储在每个连接远端的计算机上。 你可以使用 Get-PSSessionComputerNameConnectionUri 参数来获取连接到本地计算机或远程计算机的会话,即使它们不是在当前会话中创建的,也是如此。

在没有参数的情况下,Get-PSSession 将获取已在当前会话中创建的所有会话。

使用筛选参数(包括 NameIDInstanceIDStateApplicationNameConfigurationName)从 Get-PSSession 返回的会话中进行选择。

使用剩余的参数来配置临时连接,该连接可用于在你使用 ComputerNameConnectionUri 参数时运行 Get-PSSession 命令。

注意

在 Windows PowerShell 2.0 中,如果没有参数,Get-PSSession 将获取已在当前会话中创建的所有会话。 ComputerName 参数将获取已在当前会话中创建的会话以及连接到指定计算机的会话。

有关 PowerShell 会话的详细信息,请参阅 about_PSSessions

示例

示例 1:获取当前会话中创建的会话

Get-PSSession

此命令获取在当前会话中创建的所有 PSSession。 此命令不会获取在其他会话中或其他计算机上创建的 PSSessions,即使它们连接到本计算机也是如此。

示例 2:获取连接到本地计算机的会话

Get-PSSession -ComputerName "localhost"

此命令获取连接到本地计算机的 PSSession。 若要指示本地计算机,请键入该计算机名称、“localhost”或句点 (.)

此命令返回本地计算机上的所有会话,即使它们是在不同会话中或不同计算机上创建的,也是如此。

示例 3:获取连接到计算机的会话

Get-PSSession -ComputerName "Server02"

Id Name            ComputerName    State         ConfigurationName     Availability
 -- ----            ------------    -----         -----------------     ------------
  2 Session3        Server02       Disconnected  ITTasks                       Busy
  1 ScheduledJobs   Server02       Opened        Microsoft.PowerShell     Available
  3 Test            Server02       Disconnected  Microsoft.PowerShell          Busy

此命令获取连接到 Server02 计算机的 PSSession

此命令返回 Server02 上的所有会话,即使它们是在不同会话中或不同计算机上创建的,也是如此。

此输出显示了两个具有 Disconnected 状态的会话,这些会话的可用性为 Busy。 它们是在不同的会话中创建的,并且当前正在使用它们。 ScheduledJobs 会话(OpenedAvailable)是在当前会话中创建的。

示例 4:保存此命令的结果

New-PSSession -ComputerName Server01, Server02, Server03
$s1, $s2, $s3 = Get-PSSession

此示例显示了如何将 Get-PSSession 命令的结果保存在多个变量中。

第一个命令使用 New-PSSession cmdlet 在三台远程计算机上创建 PSSession

第二个命令使用 Get-PSSession cmdlet 来获取这三个 PSSession。 然后,将其中的每个 PSSession 分别保存在一个单独的变量中。

PowerShell 将对象数组分配给变量数组时,会将第一个对象分配给第一个变量,将第二个对象分配给第二个变量,依此类推。 如果对象多于变量,则会将数组中所有剩余的对象都分配给最后一个变量。 如果变量多于对象,则弃用额外的变量。

示例 5:使用实例 ID 删除会话

Get-PSSession | Format-Table -Property ComputerName, InstanceID
$s = Get-PSSession -InstanceID a786be29-a6bb-40da-80fb-782c67f7db0f
Remove-PSSession -Session $s

此示例显示了如何使用实例 ID 获取 PSSession,然后再将该 PSSession 删除。

第一个命令获取在当前会话中创建的所有 PSSession。 它将 PSSession 发送给 Format-Table cmdlet,此 cmdlet 将显示每个 PSSessionComputerNameInstanceID 属性。

第二个命令使用 Get-PSSession cmdlet 来获取特定的 PSSession,并将其保存在 $s 变量中。 此命令使用 InstanceID 参数标识 PSSession

第三个命令使用 Remove-PSSession cmdlet 删除 $s 变量中的 PSSession

示例 6:获取具有特定名称的会话

此示例中的命令将查找具有特定名称格式且使用特定会话配置的会话,然后将连接到该会话。 你可以使用此类命令来查找同事在其中启动任务的会话,然后连接该会话以完成该任务。

Get-PSSession -ComputerName Server02, Server12 -Name BackupJob* -ConfigurationName ITTasks -SessionOption @{OperationTimeout=240000}

Id Name            ComputerName    State         ConfigurationName     Availability
 -- ----            ------------    -----         -----------------     ------------
  3 BackupJob04     Server02        Disconnected        ITTasks                  None

$s = Get-PSSession -ComputerName Server02 -Name BackupJob04 -ConfigurationName ITTasks | Connect-PSSession
$s

Id Name            ComputerName    State         ConfigurationName     Availability
-- ----            ------------    -----         -----------------     ------------
 5 BackupJob04     Server02        Opened        ITTasks                  Available

第一个命令获取 Server02 和 Server12 远程计算机上的会话,这些计算机的名称以 BackupJob 开头,并使用 ITTasks 会话配置。该命令使用 Name 参数来指定名称模式和 ConfigurationName 参数来指定会话配置。 SessionOption 参数值是一个哈希表,可将 OperationTimeout 值设置为 240000 毫秒(4 分钟)。 此设置为命令提供了更多完成时间。ConfigurationNameSessionOption 参数用于配置在每台计算机上运行 Get-PSSession cmdlet 的临时会话。输出显示命令返回 BackupJob04 会话。 如果该会话断开连接且 AvailabilityNone,这指示它不在使用中。

第二个命令使用 Get-PSSession cmdlet 获取 BackupJob04 会话,并使用 Connect-PSSession cmdlet 断开与该会话的连接。 该命令将该会话保存在 $s 变量中。

第三个命令获取 $s 变量中的会话。 该输出显示 Connect-PSSession 命令已成功。 此会话处于 Opened 状态且可用。

示例 7:使用其 ID 获取会话

Get-PSSession -Id 2

此命令获取 ID 为 2PSSession。 由于 ID 属性值仅在当前会话中是唯一的,因此 ID 参数仅对本地命令有效。

参数

-AllowRedirection

指示此 cmdlet 允许将此连接重定向到备用统一资源标识符 (URI)。 默认情况下,PowerShell 不重定向连接。

此参数将创建的临时连接配置为运行带有 ConnectionUri 参数的 Get-PSSession 命令。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:SwitchParameter
Position:Named
默认值:False
必需:False
接受管道输入:False
接受通配符:False

-ApplicationName

指定应用程序的名称。 此 cmdlet 仅连接到使用指定应用程序的会话。

输入连接 URI 的应用程序名称段。 例如,在以下连接 URI 中,应用程序名称为 WSMan:http://localhost:5985/WSMAN。 会话的应用程序名称存储在该会话的 Runspace.ConnectionInfo.AppName 属性中。

此参数的值用于选择和筛选会话。 它不会更改会话使用的应用程序。

类型:String
Position:Named
默认值:All sessions
必需:False
接受管道输入:True
接受通配符:False

-Authentication

指定用于对运行 Get-PSSession 命令的会话凭据进行身份验证的机制。

此参数将创建的临时连接配置为运行带有 ComputerNameConnectionUri 参数的 Get-PSSession 命令。

此参数的可接受值为:

  • Default
  • Basic
  • CredSSP
  • Digest
  • Kerberos
  • Negotiate
  • NegotiateWithImplicitCredential

默认值为 Default

有关此参数的值的详细信息,请参阅 AuthenticationMechanism 枚举

注意

在凭据安全支持提供程序 (CredSSP) 身份验证中,用户凭据传递到远程计算机中进行验证,这种验证用于要求对多个资源进行验证的命令(例如访问远程网络共享时使用的命令)。 此机制增加了远程操作的安全风险。 如果远程计算机的安全受到威胁,则传递给该计算机的凭据可用于控制网络会话。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:AuthenticationMechanism
接受的值:Default, Basic, Negotiate, NegotiateWithImplicitCredential, Credssp, Digest, Kerberos
Position:Named
默认值:Default
必需:False
接受管道输入:False
接受通配符:False

-CertificateThumbprint

指定有权创建运行 Get-PSSession 命令的会话的用户帐户的数字公钥证书 (X509)。 输入证书的证书指纹。

此参数将创建的临时连接配置为运行带有 ComputerNameConnectionUri 参数的 Get-PSSession 命令。

在基于客户端证书的身份验证中使用证书。 证书只能映射到本地用户帐户,而不适用于域帐户。

若要获取证书指纹,请使用 PowerShell Cert: 驱动器中的 Get-ItemGet-ChildItem 命令。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:String
Position:Named
默认值:None
必需:False
接受管道输入:False
接受通配符:False

-ComputerName

指定计算机的名称数组。 获取连接到指定计算机的会话。 不允许使用通配符。 没有默认值。

从 Windows PowerShell 3.0 开始,PSSession 对象将存储在每个连接远端的计算机上。 若要获取指定计算机上的会话,PowerShell 将创建一个到每台计算机的临时连接,并运行 Get-PSSession 命令。

键入一台或多台计算机的 NetBIOS 名称、IP 地址或完全限定的域名。 若要指定本地计算机,请键入计算机名称 localhost 或点 (.)。

注意

此参数只能从运行 Windows PowerShell 3.0 或更高版本的 PowerShell 的计算机获取会话。 早期版本不存储会话。

类型:String[]
别名:Cn
Position:0
默认值:None
必需:True
接受管道输入:True
接受通配符:False

-ConfigurationName

指定配置的名称。 此 cmdlet 仅获取到使用指定会话配置的会话。

输入会话配置的配置名称或完全限定的资源 URI。 如果只指定配置名称,则会预置以下架构 URI:http://schemas.microsoft.com/powershell。 会话的配置名称存储在该会话的 ConfigurationName 属性中。

此参数的值用于选择和筛选会话。 它不会更改会话使用的会话配置。

有关会话配置的详细信息,请参阅 about_Session_Configurations

类型:String
Position:Named
默认值:All sessions
必需:False
接受管道输入:True
接受通配符:False

-ConnectionUri

指定一个 URI ,该标识符定义了运行 Get-PSSession 命令的临时会话的连接终结点。 URI 必须完全限定。

此参数将创建的临时连接配置为运行带有 ConnectionUri 参数的 Get-PSSession 命令。

此字符串的格式为:

<Transport>://<ComputerName>:<Port\>/<ApplicationName>

默认值为:http://localhost:5985/WSMAN

如果未指定 ConnectionUri,则可以使用 UseSSLComputerNamePortApplicationName 参数来指定 ConnectionURI 值。 URI 的 Transport 段的有效值为 HTTP 和 HTTPS。 如果使用传输段指定连接 URI,但不指定端口,将使用以下标准端口来创建会话:80 用于 HTTP,443 用于 HTTPS。 若要使用 PowerShell 远程处理的默认端口,请指定端口 5985 用于 HTTP,或端口 5986 用于 HTTPS。

如果目标计算机将连接重定向到另一个 URI,PowerShell 将阻止重定向,除非在命令中使用 AllowRedirection 参数。

已在 Windows PowerShell 3.0 中引入了此参数。

此参数只能从运行 Windows PowerShell 3.0 或更高版本的 Windows PowerShell 的计算机获取会话。 早期版本不存储会话。

类型:Uri[]
别名:URI, CU
Position:0
默认值:Http://localhost:5985/WSMAN
必需:True
接受管道输入:True
接受通配符:False

-ContainerId

指定容器的 ID 数组。 此 cmdlet 启动与每个指定容器的交互式会话。 使用 docker ps 命令获取容器 ID 的列表。 有关详细信息,请参阅 docker ps 命令的帮助。

类型:String[]
Position:Named
默认值:None
必需:True
接受管道输入:True
接受通配符:False

-Credential

指定用户凭据。 此 cmdlet 使用指定用户的权限来运行该命令。 指定有权连接到远程计算机并运行 Get-PSSession 命令的用户帐户。 默认为当前用户。

键入用户名(如 User01Domain01\User01),或输入 Get-Credential cmdlet 生成的 PSCredential 对象。 如果键入用户名,系统会提示输入密码。

凭据存储在 PSCredential 对象中,密码存储为 SecureString

注意

有关 SecureString 数据保护的详细信息,请参阅 SecureString 的安全性如何?

此参数将创建的临时连接配置为运行带有 ComputerNameConnectionUri 参数的 Get-PSSession 命令。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:PSCredential
Position:Named
默认值:Current user
必需:False
接受管道输入:False
接受通配符:False

-Id

指定会话 ID 数组。 此 cmdlet 仅获取具有指定 ID 的会话。 键入一个或多个 ID,用逗号分隔,或使用范围运算符 (..) 指定一系列 ID。 ID 参数与 ComputerName 参数不能一起使用。

ID 是一个整数,用于在当前会话中唯一标识用户托管的会话。 它比 InstanceId 更容易记住和键入,但它仅在当前会话中是唯一的。 会话 ID 存储在该会话的 ID 属性中。

类型:Int32[]
Position:0
默认值:All sessions
必需:True
接受管道输入:True
接受通配符:False

-InstanceId

指定会话实例 ID 的数组。 此 cmdlet 仅获取具有指定实例 ID 的会话。

实例 ID 是一个 GUID,用于在本地或远程计算机上唯一标识某个会话。 即使在 PowerShell 中运行了多个会话,InstanceID 也是唯一的。

会话的实例 ID 存储在该会话的 InstanceID 属性中。

类型:Guid[]
Position:Named
默认值:All sessions
必需:False
接受管道输入:False
接受通配符:False

-Name

指定会话名称数组。 此 cmdlet 仅获取具有指定友好名称的会话。 允许使用通配符。

会话的友好名称存储在该会话的 Name 属性中。

类型:String[]
Position:Named
默认值:All sessions
必需:False
接受管道输入:True
接受通配符:True

-Port

指定用于可运行 Get-PSSession 命令的临时连接的指定网络端口。 若要连接到一台远程计算机,则必须在该连接所用的端口上侦听远程计算机。 默认端口为 HTTP 的 WinRM 端口 5985 和 HTTPS 的 WinRM 端口 5986

使用备用端口之前,你必须在远程计算机上配置 WinRM 侦听器,才能在该端口上进行侦听。 若要配置侦听器,请在 PowerShell 提示符下键入以下两个命令:

Remove-Item -Path WSMan:\Localhost\listener\listener* -Recurse

New-Item -Path WSMan:\Localhost\listener -Transport http -Address * -Port \<port-number\>

此参数将创建的临时连接配置为运行带有 ComputerNameConnectionUri 参数的 Get-PSSession 命令。

除非必要,否则不要使用 Port 参数。 在命令中设置的端口适用于运行该命令的所有计算机或会话。 备用端口设置可能会阻止在所有计算机上运行该命令。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:Int32
Position:Named
默认值:5985, 5986
必需:False
接受管道输入:False
接受通配符:False

-SessionOption

为该会话指定高级选项。 输入 SessionOption 对象(例如使用 New-PSSessionOption cmdlet 创建的对象),或输入哈希表,其中的键是会话选项名称,而值是会话选项值。

这些选项的默认值由 $PSSessionOption 首选项变量的值(如果已设置)确定。 否则,通过在会话配置中设置的选项创建默认值。

会话选项值优先于在 $PSSessionOption 首选项变量和会话配置中设置的会话的默认值。 但是,它们不优先于在会话配置中设置的最大值、配额或限制。

有关会话选项(包括默认值)的说明,请参阅 New-PSSessionOption。 有关 $PSSessionOption 首选项变量的信息,请参阅 about_Preference_Variables。 有关会话配置的详细信息,请参阅 about_Session_Configurations

类型:PSSessionOption
Position:Named
默认值:None
必需:False
接受管道输入:False
接受通配符:False

-State

指定会话状态。 此 cmdlet 仅获取处于指定状态的会话。 此参数的可接受的值是 AllOpenedDisconnectedClosedBroken。 默认值是 All

会话状态值相对于当前会话。 没有在当前会话中创建的会话以及没有连接到当前会话的会话的状态为 Disconnected,即使它们连接到不同的会话也是如此。

会话的状态存储在该会话的 State 属性中。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:SessionFilterState
接受的值:All, Opened, Disconnected, Closed, Broken
Position:Named
默认值:All
必需:False
接受管道输入:False
接受通配符:False

-ThrottleLimit

指定为运行 Get-PSSession 命令可建立的并发连接的最大数目。 如果省略此参数或输入 0(零)值,则使用默认值 32。 节流限制仅适用于当前命令,而不适用于会话或计算机。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:Int32
Position:Named
默认值:32
必需:False
接受管道输入:False
接受通配符:False

-UseSSL

表示此 cmdlet 使用安全套接字层 (SSL) 协议来建立用于运行 Get-PSSession 命令的连接。 默认情况下,不使用 SSL。 如果你使用此参数,但 SSL 在用于此命令的端口上不可用,则命令将失败。

此参数将创建的临时连接配置为运行带有 ComputerName 参数的 Get-PSSession 命令。

已在 Windows PowerShell 3.0 中引入了此参数。

类型:SwitchParameter
Position:Named
默认值:False
必需:False
接受管道输入:False
接受通配符:False

-VMId

指定虚拟机的 ID 数组。 此 cmdlet 启动与每个指定虚拟机的交互式会话。 若要查看可用的虚拟机,请使用以下命令:

Get-VM | Select-Object -Property Name, ID

类型:Guid[]
别名:VMGuid
Position:Named
默认值:None
必需:True
接受管道输入:True
接受通配符:False

-VMName

指定一个虚拟机的名称数组。 此 cmdlet 启动与每个指定虚拟机的交互式会话。 若要查看可用的虚拟机,请使用 Get-VM cmdlet。

类型:String[]
Position:Named
默认值:None
必需:True
接受管道输入:True
接受通配符:False

输入

None

不能通过管道将对象传递给此 cmdlet。

输出

PSSession

备注

PowerShell 包含 Get-PSSession 的以下别名:

  • 所有平台:

    • gsn
  • 此 cmdlet 获取用户托管的会话“PSSession”,例如通过使用 New-PSSessionEnter-PSSessionInvoke-Command cmdlet 创建的会话。 它不会获取启动 PowerShell 时所创建的系统托管的会话。

  • 从 Windows PowerShell 3.0 开始,PSSession 对象将存储在位于连接的“服务器端”或接收端的计算机上。 若要获取存储在本地计算机或远程计算机上的会话,PowerShell 将建立与指定计算机的临时会话,并在该会话中运行查询命令。

  • 若要获取连接到远程计算机的会话,请使用 ComputerNameConnectionUri 参数来指定远程计算机。 若要筛选 Get-PSSession 获取的会话,请使用 NameIDInstanceIDState 参数。 使用剩余的参数配置 Get-PSSession 使用的临时会话。

  • 当你使用 ComputerNameConnectionUri 参数时,Get-PSSession 将仅从运行 Windows PowerShell 3.0 和更高版本的 PowerShell 的计算机中获取会话。

  • PSSessionState 属性值相对于当前会话。 因此,值 Disconnected 意味着 PSSession 未连接到当前会话。 但是,这并不意味着 PSSession 已与所有会话断开连接。 它可能连接到另一个会话。 若要确定是否可以从当前会话连接或重新连接到 PSSession,请使用 Availability 属性。

AvailabilityNone 值指示可连接会话。 值 Busy 指示无法连接 PSSession,因为它已连接另一个会话。

有关会话 State 属性的值的详细信息,请参阅 RunspaceState 枚举

有关会话可用性属性的值的详细信息,请参阅 RunspaceState 枚举