Partilhar via


New-PSSessionOption

Cria um objeto que contém opções avançadas para uma PSSession.

Sintaxe

New-PSSessionOption [-ApplicationArguments <PSPrimitiveDictionary>] [-CancelTimeOut <int>] [-Culture <CultureInfo>] [-IdleTimeOut <int>] [-MaximumReceivedDataSizePerCommand <int>] [-MaximumReceivedObjectSize <int>] [-MaximumRedirection <int>] [-NoCompression] [-NoEncryption] [-NoMachineProfile] [-OpenTimeOut <int>] [-OperationTimeOut <int>] [-ProxyAccessType {<None> | <IEConfig> | <WinHttpConfig> | <AutoDetect> | <NoProxyServer>}] [-ProxyAuthentication {<Default> | <Basic> | <Negotiate> | <NegotiateWithImplicitCredential> | <Credssp> | <Digest> | <Kerberos>}] [-ProxyCredential <PSCredential>] [-SkipCACheck] [-SkipCNCheck] [-SkipRevocationCheck] [-UICulture <CultureInfo>] [-UseUTF16] [<CommonParameters>]

Descrição

O cmdlet New-PSSessionOption cria um objeto que contém opções avançadas para uma PSSession. Você poderá usar o objeto como o valor do parâmetro SessionOption de cmdlets que criam uma PSSession, como New-PSSession, Enter-PSSession e Invoke-Command.

Sem parâmetros, New-PSSessionOption gera um objeto que contém os valores padrão para todas as opções. Como todas as propriedades podem ser editadas, você poderá usar o objeto resultante como um modelo e criar objetos de opção padrão para sua empresa.

Parâmetros

-ApplicationArguments <PSPrimitiveDictionary>

Especifica uma tabela de hash que é enviada diretamente à configuração de sessão sem interpretação. Essa tabela de hash está disponível para a configuração de sessão como uma propriedade da classe PSSenderInfo.

Necessário?

false

Posição?

named

Valor padrão

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-CancelTimeOut <int>

Determina quanto tempo o Windows PowerShell aguarda uma operação de cancelamento (CTRL + C) ser concluída antes de encerrá-la. Insira um valor em milissegundos.

O valor padrão é 60000 (um minuto). Um valor 0 (zero) significa que não há tempo limite; o comando continuará indefinidamente.

Necessário?

false

Posição?

named

Valor padrão

60000

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-Culture <CultureInfo>

Especifica a cultura a ser usada para a PSSession. Insira um nome de cultura no formato <códigodeidioma2>-<país/códigoderegião2>, como "ja-jP", uma variável que contenha um objeto CultureInfo ou um comando que obtenha um objeto CultureInfo, como "Get-Culture".

O valor padrão é $null, e a cultura definida no sistema operacional quando a PSSession é criada é usado na PSSession.

Necessário?

false

Posição?

named

Valor padrão

Cultura atual

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-IdleTimeOut <int>

Determina quanto tempo a PSSession permanecerá aberta se o computador remoto não receber nenhuma comunicação do computador local, incluindo o sinal de pulsação. Quando o intervalo expira, a PSSession é fechada.

Insira um valor em milissegundos. O valor padrão é 240000 (4 minutos). O valor mínimo permitido é 60000 (1 minuto).

Se os computadores local e remoto especificarem um valor de tempo limite ocioso, a PSSession usará o valor de tempo limite mais curto. O computador local pode definir um valor de tempo limite ocioso usando esse parâmetro ou definindo um tempo limite ocioso na variável de preferência $PSSessionOption. O computador remoto pode especificar um valor de tempo limite ocioso na configuração WS-Management (WSMAN:\localhost\shell\idletimeout).

Necessário?

false

Posição?

named

Valor padrão

240000

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-MaximumReceivedDataSizePerCommand <int>

Especifica o número máximo de bytes que o computador local pode receber do computador remoto em um único comando. Insira um valor em bytes. Por padrão, não há nenhum limite de tamanho dos dados.

O objetivo dessa opção é proteger os recursos no computador cliente.

Necessário?

false

Posição?

named

Valor padrão

Sem limite

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-MaximumReceivedObjectSize <int>

Especifica o tamanho máximo de um objeto que o computador local pode receber do computador remoto. Insira um valor em bytes. Por padrão, não há nenhum limite de tamanho dos dados.

O objetivo dessa opção é proteger os recursos no computador cliente.

Necessário?

false

Posição?

named

Valor padrão

Sem limite

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-MaximumRedirection <int>

Determina quantas vezes o Windows PowerShell redireciona uma conexão para um URI (Uniform Resource Identifier) alternativo antes de a conexão falhar. O valor padrão é 5. O valor 0 (zero) impede todo o redirecionamento.

Essa opção é usada na PSSession somente quando o parâmetro AllowRedirection é usado no comando que cria a PSSession.

Necessário?

false

Posição?

named

Valor padrão

5

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-NoCompression

Desativa a compactação de pacotes na PSSession. A compactação usa mais ciclos de processador, mas torna a transmissão mais rápida.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-NoEncryption

Desativa a criptografia de dados.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-NoMachineProfile

Impede o carregando do perfil de usuário do Windows. Com isso, a PSSession poderá ser criada mais rapidamente, mas as configurações do Registro específicas ao usuário, itens como variáveis de ambiente e certificados, não estarão disponíveis na PSSession.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-OpenTimeOut <int>

Determina quanto tempo o computador cliente aguarda a conexão de sessão ser estabelecida. Quando o intervalo expira, o comando para estabelecer a conexão falha. Insira um valor em milissegundos.

O valor padrão é 180000 (3 minutos). Um valor 0 (zero) significa que não há tempo limite; o comando continuará indefinidamente.

Necessário?

false

Posição?

named

Valor padrão

180000

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-OperationTimeOut <int>

Determina o tempo máximo de execução de qualquer operação na PSSession. Quando o intervalo expira, a operação falha. Insira um valor em milissegundos.

O valor padrão é 180000 (3 minutos). Um valor 0 (zero) significa que não há tempo limite; a operação continuará indefinidamente.

Necessário?

false

Posição?

named

Valor padrão

180000

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-ProxyAccessType <ProxyAccessType>

Determina qual mecanismo é usado para resolver o nome de host. Os valores válidos são: IEConfig, WinHttpConfig, AutoDetect, NoProxyServer e None. O valor padrão é None.

Para obter mais informações sobre os valores desse parâmetro, consulte a descrição da enumeração System.Management.Automation.Remoting.ProxyAccessType na Biblioteca MSDN, em https://go.microsoft.com/fwlink/?LinkId=144756.

Necessário?

false

Posição?

named

Valor padrão

Nenhum

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-ProxyAuthentication <AuthenticationMechanism>

Especifica o método de autenticação usado para a resolução de proxy. Os valores válidos são: o Basic, Digest e Negotiate. O valor padrão é Negotiate.

Para obter mais informações sobre os valores desse parâmetro, consulte a descrição da enumeração System.Management.Automation.Runspaces.AuthenticationMechanism na biblioteca MSDN, em https://go.microsoft.com/fwlink/?LinkID=144382.

Necessário?

false

Posição?

named

Valor padrão

Negotiate

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-ProxyCredential <PSCredential>

Especifica as credenciais a serem usadas para a autenticação de proxy. Insira uma variável que contenha um objeto PSCredential ou um comando que obtenha um objeto PSCredential, como Get-Credential. Se essa opção não for definida, nenhuma credencial será especificada.

Necessário?

false

Posição?

named

Valor padrão

Nenhum

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-SkipCACheck

Especifica que, durante a conexão por HTTPS, o cliente não valida que o certificado do servidor esteja assinado por uma CA (autoridade de certificação) confiável.

Use essa opção somente quando o computador remoto for confiável com o uso de outro mecanismo, por exemplo, quando o computador remoto faz parte de uma rede fisicamente segura e isolada ou está listado como um host confiável em uma configuração WinRM.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-SkipCNCheck

Especifica que um CN (nome comum) de certificado do servidor não precisa corresponder ao nome do host do servidor. Essa opção é usada apenas em operações remotas que usam o protocolo HTTP.

Use-a somente para computadores confiáveis.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-SkipRevocationCheck

Não valida o status de revogação do certificado do servidor.

Necessário?

false

Posição?

named

Valor padrão

False

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-UICulture <CultureInfo>

Especifica a cultura de interface do usuário a ser usada para a PSSession.

Insira um nome de cultura no formato <códigodeidioma2>-<país/códigoderegião2>, como "ja-jP", uma variável que contenha um objeto CultureInfo ou um comando que obtenha um objeto CultureInfo, como Get-Culture.

O valor padrão é $null, e a cultura de interface do usuário definida no sistema operacional quando a PSSession é criada é usado na PSSession.

Necessário?

false

Posição?

named

Valor padrão

Cultura da interface do usuário atual

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-UseUTF16

Codifica a solicitação no formato UTF16, em vez de no formato UTF8.

Necessário?

false

Posição?

named

Valor padrão

False (codificação UTF8)

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

<CommonParameters>

Esse cmdlet oferece suporte aos parâmetros comuns: -Verbose, -Debug, -ErrorAction, -ErrorVariable, -OutBuffer e -OutVariable. Para obter mais informações, consulte about_Commonparameters.

Entradas e saídas

O tipo de entrada é o tipo dos objetos que você pode canalizar para o cmdlet. O tipo de retorno é o tipo dos objetos que o cmdlet retorna.

Entradas

Nenhum

Você não pode canalizar a entrada para este cmdlet.

Saídas

System.Management.Automation.Remoting.PSSessionOption

Observações

Se o parâmetro SessionOption não for usado em um comando para criar uma PSSession, as opções de sessão serão determinadas pelos valores de propriedade da variável de preferência $PSSessionOption, caso esteja definida. Para obter mais informações sobre a variável $PSSessionOption, consulte about_Preference_Variables.

Exemplo 1

C:\PS>New-PSSessionOption


MaximumConnectionRedirectionCount : 5
NoCompression                     : False
NoMachineProfile                  : False
ProxyAccessType                   : IEConfig
ProxyAuthentication               : Negotiate
ProxyCredential                   :
SkipCACheck                       : False
SkipCNCheck                       : False
SkipRevocationCheck               : False
OperationTimeout                  : 00:03:00
NoEncryption                      : False
UseUTF16                          : False
Culture                           :
UICulture                         :
MaximumReceivedDataSizePerCommand :
MaximumReceivedObjectSize         :
ApplicationArguments              :
OpenTimeout                       : 00:03:00
CancelTimeout                     : 00:01:00
IdleTimeout                       : 00:04:00

Descrição
-----------
Esse comando cria um objeto de opção de sessão com todos os valores padrão.





Exemplo 2

C:\PS>$pso = new-pssessionoption -Culture "fr-fr" -MaximumReceivedObjectSize 10MB

C:\PS> new-pssession -computerName Server01 -SessionOption $pso

Descrição
-----------
Este exemplo mostra como usar um objeto de opção de sessão para configurar uma sessão.

O primeiro comando cria um novo objeto de opção de sessão e salva-o no valor da variável $pso.

O segundo comando usa o cmdlet New-PSSession para criar uma PSSession no computador remoto Server01. O comando usa o novo objeto de opção de sessão no valor da variável $pso como o valor do parâmetro SessionOption do comando.





Exemplo 3

C:\PS>enter-pssession -computername Server01 -sessionOption (new-pssessionoption -noEncryption -noCompression)

Descrição
-----------
Esse comando usa o cmdlet Enter-PSSession para iniciar uma sessão interativa com o computador Server01. O valor do parâmetro SessionOption é um comando New-PSSessionOption com os parâmetros de opção NoEncryption e NoCompression.

O comando New-PSSessionOption é colocado entre parênteses para garantir que seja executado antes do comando Enter-PSSession.





Exemplo 4

C:\PS>$a = new-pssessionoption


MaximumConnectionRedirectionCount : 5
NoCompression                     : False
NoMachineProfile                  : False
ProxyAccessType                   : IEConfig
ProxyAuthentication               : Negotiate
ProxyCredential                   :
SkipCACheck                       : False
SkipCNCheck                       : False
SkipRevocationCheck               : False
OperationTimeout                  : 00:03:00
NoEncryption                      : False
UseUTF16                          : False
Culture                           :
UICulture                         :
MaximumReceivedDataSizePerCommand :
MaximumReceivedObjectSize         :
ApplicationArguments              :
OpenTimeout                       : 00:03:00
CancelTimeout                     : 00:01:00
IdleTimeout                       : 00:04:00

C:\PS> $a.UICulture = (get-UICulture)
C:\PS> $a.OpenTimeout = (new-timespan -minutes 4)
C:\PS> $a.MaximumConnectionRedirectionCount = 1

C:\PS> $a

MaximumConnectionRedirectionCount : 1
NoCompression                     : False
NoMachineProfile                  : False
ProxyAccessType                   : IEConfig
ProxyAuthentication               : Negotiate
ProxyCredential                   :
SkipCACheck                       : False
SkipCNCheck                       : False
SkipRevocationCheck               : False
OperationTimeout                  : 00:03:00
NoEncryption                      : False
UseUTF16                          : False
Culture                           :
UICulture                         : en-US
MaximumReceivedDataSizePerCommand :
MaximumReceivedObjectSize         :
ApplicationArguments              :
OpenTimeout                       : 00:04:00
CancelTimeout                     : 00:01:00
IdleTimeout                       : 00:04:00

Descrição
-----------
Este exemplo demonstra que você pode editar o objeto de opção de sessão. Todas as propriedades têm valores de leitura/gravação.

Use este método para criar um objeto de sessão padrão para sua empresa e, em seguida, crie versões personalizadas dele para usos específicos.





Exemplo 5

C:\PS>$PSSessionOption = New-PSSessionOption -OpenTimeOut 120000

Descrição
-----------
Esse comando cria uma variável de preferência $PSSessionOption. 

Quando a variável de preferência $PSSessionOption existir na sessão, ela estabelecerá valores padrão para opções nas PSSessions criadas com os cmdlets New-PSSession, Enter-PSSession e Invoke-Command.

Para tornar a variável $PSSessionOption disponível em todas as sessões, adicione-a à sua sessão do Windows PowerShell e ao seu perfil do Windows PowerShell.

Para obter mais informações sobre a variável $PSSessionOption, consulte about_Preference_Variables. Para obter mais informações sobre perfis, consulte about_Profiles.





Exemplo 6

C:\PS>$skipCN = new-pssessionoption -SkipCNCheck

C:\PS> new-pssession -computername 171.09.21.207 -UseSSL -credential domain01\user01 -sessionOption $skipCN

Descrição
-----------
Este exemplo mostra como usar um objeto SessionOption para cumprir os requisitos para uma configuração de sessão remota.

O primeiro comando usa o cmdlet New-PSSessionOption para criar um objeto de opção de sessão com a propriedade SkipCNCheck. O comando salva o objeto de sessão resultante na variável $skipCN.

O segundo comando usa o cmdlet New-PSSession para criar uma nova PSSession em um computador remoto. A variável de verificação $skipCN é usada no valor do parâmetro SessionOption. 

Como o computador é identificado pelo seu endereço IP, o valor do parâmetro ComputerName não corresponde a nenhum dos nomes comuns no certificado usado para SSL. Com isso, a opção SkipCNCheck é necessária.





Consulte também

Conceitos

Enter-PSSession
New-PSSession
Invoke-Command