Compartilhar via


Debug-Process

Depura um ou mais processos em execução no computador local.

Sintaxe

Debug-Process [-Name] <string[]> [-Confirm] [-WhatIf] [<CommonParameters>]

Debug-Process [-Id] <Int32[]> [-Confirm] [-WhatIf] [<CommonParameters>]

Debug-Process -InputObject <Process[]> [-Confirm] [-WhatIf] [<CommonParameters>]

Descrição

O cmdlet Debug-Process anexa um depurador a um ou mais processos em execução em um computador local. Você pode especificar os processos pelo respectivo nome ou pela PID (ID do processo) ou pode enviar por pipe os objetos do processo para Debug-Process.

Debug-Process anexa o depurador registrado no momento para o processo. Antes de usar este cmdlet, verifique se o depurador foi baixado e está configurado corretamente.

Parâmetros

-Id <Int32[]>

Especifica as IDs do processo dos processos a serem depurados. O nome do parâmetro ("-Id") é opcional.

Para localizar a ID do processo de um processo, digite "Get-Process".

Necessário?

true

Posição?

1

Valor padrão

Nenhum

Aceitar entrada do pipeline?

true (ByPropertyName)

Aceitar caracteres curinga?

false

-InputObject <Process[]>

Especifica os objetos de processo que representam os processos a serem depurados. Insira uma variável que contenha os objetos de processo ou um comando que obtenha os objetos de processo, como o comando Get-Process. Você também pode enviar por pipe os objetos de processo para Debug-Process.

Necessário?

true

Posição?

named

Valor padrão

Aceitar entrada do pipeline?

true (ByValue)

Aceitar caracteres curinga?

false

-Name <string[]>

Especifica os nomes dos processos a serem depurados. Se houver mais de um processo com o mesmo nome, Debug-Process anexará um depurador a todos os processos com esse nome. O nome do parâmetro ("Name") é opcional.

Necessário?

true

Posição?

1

Valor padrão

Aceitar entrada do pipeline?

true (ByPropertyName)

Aceitar caracteres curinga?

false

-Confirm

Solicita confirmação antes da execução do comando.

Necessário?

false

Posição?

named

Valor padrão

Aceitar entrada do pipeline?

false

Aceitar caracteres curinga?

false

-WhatIf

Descreve o que aconteceria se você executasse o comando, sem executá-lo de fato.

Necessário?

false

Posição?

named

Valor padrão

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

System.Int32, System.Diagnostics.Process, System.String

Você pode enviar uma ID de processo (Int32), um objeto de processo (System.Diagnostics.Process) ou um nome de processo (String) para Debug-Process.

Saídas

Nenhum

Este cmdlet não gera nenhuma saída.

Observações

Este cmdlet usa o método AttachDebugger da classe Win32_Process de WMI (Instrumentação de Gerenciamento do Windows). Para obter mais informações sobre esse método, consulte "AttachDebugger Method" na biblioteca do MSDN (Microsoft Developer Network) em (o site pode estar em inglês).

Exemplo 1

C:\PS>debug-process -name powershell

Descrição
-----------
Esse comando anexa um depurador ao processo do PowerShell no computador.





Exemplo 2

C:\PS>debug-process -name sql*

Descrição
-----------
Esse comando anexa um depurador a todos os processos cujos nomes começam com "sql".





Exemplo 3

C:\PS>debug-process winlogon, explorer, outlook

Descrição
-----------
Esse comando anexa um depurador aos processos do Winlogon, Explorer e Outlook.





Exemplo 4

C:\PS>debug-process -id 1132, 2028

Descrição
-----------
Esse comando anexa um depurador aos processos com as IDs de processo 1132 e 2028.





Exemplo 5

C:\PS>get-process powershell | debug-process

Descrição
-----------
Esse comando anexa um depurador aos processos do PowerShell no computador. Ele usa o cmdlet Get-Process para obter os processos do PowerShell no computador e usa um operador de pipeline (|) para enviar os processos para o cmdlet Debug-Process.

Para especificar um determinado processo do PowerShell, use o parâmetro ID de Get-Process.





Exemplo 6

C:\PS>$pid | debug-process

Descrição
-----------
Esse comando anexa um depurador aos processos atuais do PowerShell no computador. 

Ele usa a variável automática $pid, que contém a ID de processo do processo atual do PowerShell. Em seguida, ele usa o operador de pipeline (|) para enviar a ID do processo para o cmdlet Debug-Process.

Para obter mais informações sobre a variável automática $pid, consulte about_Automatic_Variables.





Exemplo 7

C:\PS>get-process -computername Server01, Server02 -name MyApp | debug-process

Descrição
-----------
Esse comando anexa um depurador aos processos MyApp nos computadores Server01 e Server02.

Ele usa o cmdlet Get-Process para obter os processos MyApp nos computadores Server01 e Server02. Ele usa um operador de pipeline para enviar os processos para o cmdlet Debug-Process, que anexa os depuradores.





Exemplo 8

C:\PS>$p = get-process powershell

C:\PS> debug-process -inputobject $p

Descrição
-----------
Esse comando anexa um depurador aos processos do PowerShell no computador local. 

O primeiro comando usa o cmdlet Get-Process para obter os processos do PowerShell no computador. Ele salva o objeto de processo resultante na variável $p.

O segundo comando usa o parâmetro InputObject de Debug-Process para enviar o objeto de processo na variável $p para Debug-Process.





Consulte também

Conceitos

Get-Process
Start-Process
Stop-Process
Wait-Process
Debug-Process