Compartilhar via


Restart-Computer

Reinicia o sistema operacional em computadores locais e remotos.

Sintaxe

Restart-Computer
       [-WsmanAuthentication <String>]
       [[-ComputerName] <String[]>]
       [[-Credential]<PSCredential>]
       [-Force]
       [-Wait]
       [-Timeout <Int32>]
       [-For <WaitForServiceTypes>]
       [-Delay <Int16>]
       [-WhatIf]
       [-Confirm]
       [<CommonParameters>]

Description

Esse cmdlet só está disponível na plataforma Windows.

O Restart-Computer cmdlet reinicia o sistema operacional nos computadores locais e remotos.

Você pode usar os parâmetros de para executar as operações de reinicialização, especificar os níveis de Restart-Computer autenticação e credenciais alternativas, limitar as operações executadas ao mesmo tempo e forçar uma reinicialização imediata.

A partir do Windows PowerShell 3.0, você pode aguardar a conclusão da reinicialização antes de executar o próximo comando. Especifique um tempo limite de espera e um intervalo de consulta e aguarde até que serviços específicos estejam disponíveis no computador reiniciado. Esse recurso o torna prático de usar Restart-Computer em scripts e funções.

Exemplos

Exemplo 1: Reinicie o computador local

Restart-Computer Reinicia o computador local.

Restart-Computer

Exemplo 2: Reiniciar vários computadores

Restart-Computer pode reiniciar computadores remotos e locais. O parâmetro ComputerName aceita uma matriz de nomes de computador.

Restart-Computer -ComputerName Server01, Server02, localhost

Exemplo 3: Obter nomes de computador de um arquivo de texto

Restart-Computer Obtém uma lista de nomes de computador de um arquivo de texto e reinicia os computadores. O parâmetro ComputerName não é especificado. Mas como é o primeiro parâmetro de posição, ele aceita os nomes de computador do arquivo de texto que são enviados pelo pipeline.

Get-Content -Path C:\Domain01.txt | Restart-Computer

Get-Content usa o parâmetro Path para obter uma lista de nomes de computador de um arquivo de texto, Domain01.txt. Os nomes dos computadores são enviados pelo pipeline. Restart-Computer reinicia cada computador.

Exemplo 4: Forçar a reinicialização de computadores listados em um arquivo de texto

Este exemplo força uma reinicialização imediata dos computadores listados no Domain01.txt arquivo. Os nomes de computador do arquivo de texto são armazenados em uma variável. O parâmetro Force força uma reinicialização imediata.

$Names = Get-Content -Path C:\Domain01.txt
$Creds = Get-Credential
Restart-Computer -ComputerName $Names -Credential $Creds -Force

Get-Content usa o parâmetro Path para obter uma lista de nomes de computador de um arquivo de texto, Domain01.txt. Os nomes dos computadores são armazenados na variável $Names. Get-Credential solicita um nome de usuário e senha e armazena os valores na variável $Creds. Restart-Computer usa os parâmetros ComputerName e Credential com suas variáveis. O parâmetro Force causa uma reinicialização imediata de cada computador.

Exemplo 6: Reinicie um computador remoto e aguarde o PowerShell

Restart-Computer reinicia o computador remoto e aguarda até 5 minutos (300 segundos) para que o PowerShell fique disponível no computador reiniciado antes de continuar.

Restart-Computer -ComputerName Server01 -Wait -For PowerShell -Timeout 300 -Delay 2

Restart-Computer usa o parâmetro ComputerName para especificar Server01. O parâmetro Wait aguarda a conclusão da reinicialização. O For especifica que o PowerShell pode executar comandos no computador remoto. O parâmetro Timeout especifica uma espera de cinco minutos. O parâmetro Delay consulta o computador remoto a cada dois segundos para determinar se ele foi reiniciado.

Exemplo 7: Reiniciar um computador usando WsmanAuthentication

Restart-Computer reinicia o computador remoto usando o mecanismo WsmanAuthentication . A autenticação Kerberos determina se o usuário atual tem permissão para reiniciar o computador remoto. Para obter mais informações, consulte AuthenticationMechanism.

Restart-Computer -ComputerName Server01 -WsmanAuthentication Kerberos

Restart-Computer usa o parâmetro ComputerName para especificar o computador remoto, Server01. O parâmetro WsmanAuthentication especifica o método de autenticação como Kerberos.

Parâmetros

-ComputerName

Especifica um nome de computador ou uma matriz separada por vírgulas de nomes de computador. Restart-Computer aceita objetos ComputerName do pipeline ou variáveis.

Digite o nome NetBIOS, um endereço IP ou um nome de domínio totalmente qualificado de um computador remoto. Para especificar o computador local, digite o nome do computador, um ponto .ou localhost.

Esse parâmetro não depende da comunicação remota do PowerShell. Você pode usar o parâmetro ComputerName mesmo que seu computador não esteja configurado para executar comandos remotos.

Se o parâmetro ComputerName não for especificado, Restart-Computer reiniciará o computador local.

Tipo:String[]
Aliases:CN, __SERVER, Server, IPAddress
Cargo:0
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:True
Aceitar caracteres curinga:False

-Confirm

Solicita confirmação antes de executar Restart-Computero .

Tipo:SwitchParameter
Aliases:cf
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Credential

Especifica uma conta de usuário que tem permissão para executar essa ação. O padrão é o usuário atual.

Digite um nome de usuário, como User01 ou Domain01\User01, ou insira um objeto PSCredential gerado pelo Get-Credential cmdlet. Se você digitar um nome de usuário, será solicitado que você insira a senha.

As credenciais são armazenadas em um objeto PSCredential e a senha é armazenada como um SecureString.

Observação

Para obter mais informações sobre a proteção de dados do SecureString , consulte Quão seguro é o SecureString?.

Tipo:PSCredential
Cargo:1
Valor padrão:Current user
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Delay

Especifica a frequência das consultas, em segundos. O PowerShell consulta o serviço especificado pelo parâmetro For para determinar se o serviço está disponível depois que o computador é reiniciado.

Esse parâmetro é válido somente junto com os parâmetros Wait e For .

Este parâmetro foi introduzido no Windows PowerShell 3.0.

Se o parâmetro Delay não for especificado, Restart-Computer usará um atraso de cinco segundos.

Tipo:Int16
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-For

Especifica o comportamento do PowerShell enquanto ele aguarda que o serviço ou recurso especificado fique disponível após a reinicialização do computador. Esse parâmetro só é válido com o parâmetro Wait .

Os valores aceitáveis para esse parâmetro são:

  • Padrão: aguarda a reinicialização do PowerShell.
  • PowerShell: pode executar comandos em uma sessão remota do PowerShell no computador.
  • WMI: recebe uma resposta a uma consulta Win32_ComputerSystem para o computador.
  • WinRM: pode estabelecer uma sessão remota para o computador usando o WS-Management.

Este parâmetro foi introduzido no Windows PowerShell 3.0.

Tipo:WaitForServiceTypes
Valores aceitos:Wmi, WinRM, PowerShell
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Force

Força uma reinicialização imediata do computador.

Tipo:SwitchParameter
Aliases:f
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Timeout

Especifica a duração da espera, em segundos. Quando o tempo limite expirar, Restart-Computer retorna ao prompt de comando, mesmo que os computadores não sejam reiniciados.

O parâmetro Timeout só é válido com o parâmetro Wait . Timeout substitui o período de espera indefinido do parâmetro Wait .

Este parâmetro foi introduzido no Windows PowerShell 3.0.

Tipo:Int32
Aliases:TimeoutSec
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-Wait

Restart-Computer suprime o prompt do PowerShell e bloqueia o pipeline até que os computadores sejam reiniciados. Você pode usar esse parâmetro em um script para reiniciar computadores e continuar a processar quando a reinicialização for concluída.

O parâmetro Wait aguarda indefinidamente a reinicialização dos computadores. Você pode usar Timeout para ajustar o tempo e os parâmetros For e Delay para aguardar que serviços específicos fiquem disponíveis nos computadores reiniciados.

O parâmetro Wait não é válido quando você está reiniciando o computador local. Se o valor do parâmetro ComputerName contiver os nomes dos computadores remotos e do computador local, Restart-Computer o gerará um erro de não encerramento para Aguardar no computador local, mas aguardará a reinicialização dos computadores remotos.

Este parâmetro foi introduzido no Windows PowerShell 3.0.

Tipo:SwitchParameter
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-WhatIf

Mostra o que aconteceria se o Restart-Computer fosse executado. O Restart-Computer cmdlet não é executado.

Tipo:SwitchParameter
Aliases:wi
Cargo:Named
Valor padrão:False
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

-WsmanAuthentication

Especifica o mecanismo usado para autenticar as credenciais do usuário. Este parâmetro foi introduzido no Windows PowerShell 3.0.

Os valores aceitáveis para esse parâmetro são: Basic, CredSSP, Default, Digest, Kerberos e Negotiate.

Para obter mais informações, consulte AuthenticationMechanism.

Aviso

A autenticação do Provedor de Serviços de Segurança de Credenciais (CredSSP), na qual as credenciais do usuário são passadas para um computador remoto para serem autenticadas, foi projetada para comandos que exigem autenticação em mais de um recurso, como acessar um compartilhamento de rede remoto. Esse mecanismo aumenta o risco de segurança da operação remota. Se o computador remoto estiver comprometido, as credenciais que são passadas a ele podem ser usadas para controlar a sessão de rede.

Tipo:String
Valores aceitos:Basic, CredSSP, Default, Digest, Kerberos, Negotiate
Cargo:Named
Valor padrão:None
Obrigatório:False
Aceitar a entrada de pipeline:False
Aceitar caracteres curinga:False

Entradas

String

Você pode canalizar uma cadeia de caracteres que contém um nome de computador para esse cmdlet.

Saídas

None

Esse cmdlet não retorna nenhuma saída.

Observações

  • No Windows, Restart-Computer usa o método Win32Shutdown da classe de Win32_OperatingSystem WMI (Instrumentação de Gerenciamento do Windows). Esse método requer que o privilégio SeShutdownPrivilege esteja habilitado para a conta de usuário usada para reiniciar o computador.
  • No Linux e Mac OS, Restart-Computer usa a /sbin/shutdown ferramenta bash.