Condividi tramite


Debug-Process

Esegue il debug di uno o più processi in esecuzione nel computer locale.

Sintassi

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

Descrizione

Il cmdlet Debug-Process collega un debugger a uno o più processi in esecuzione in un computer locale. È possibile specificare i processi in base al nome del processo o all'ID processo (PID) oppure è possibile inviare tramite pipe oggetti di elaborazione a questo cmdlet.

Questo cmdlet collega il debugger attualmente registrato per il processo. Prima di usare questo cmdlet, verificare che sia stato scaricato e correttamente configurato un debugger.

Esempio

Esempio 1: Collegare un debugger a un processo nel computer

PS C:\> Debug-Process -Name "Windows Powershell"

Questo comando collega un debugger al processo di Windows PowerShell nel computer.

Esempio 2: Collegare un debugger a tutti i processi che iniziano con la stringa specificata

PS C:\> Debug-Process -Name "SQL*"

Questo comando collega un debugger a tutti i processi con nomi che iniziano con SQL.

Esempio 3: Collegare un debugger a più processi

PS C:\> Debug-Process "Winlogon", "Explorer", "Outlook"

Questo comando collega un debugger ai processi Winlogon, Explorer e Outlook.

Esempio 4: Collegare un debugger a più ID processo

PS C:\> Debug-Process -Id 1132, 2028

Questo comando collega un debugger ai processi con ID processo 1132 e 2028.

Esempio 5: Usare Get-Process per ottenere un processo e quindi collegarvi un debugger

PS C:\> Get-Process "Windows PowerShell" | Debug-Process

Questo comando collega un debugger ai processi Windows PowerShell nel computer. Usa il cmdlet Get-Process per ottenere i processi Windows PowerShell nel computer e usa un operatore pipeline (|) per inviare i processi al cmdlet Debug-Process.

Per specificare un particolare processo di PowerShell, usare il parametro ID di Get-Process.

Esempio 6: Collegare un debugger a un processo corrente nel computer locale

PS C:\> $PID | Debug-Process

Questo comando collega un debugger ai processi di Windows PowerShell correnti nel computer.

Il comando usa la variabile automatica $PID che contiene l'ID processo del processo di Windows PowerShell corrente. Usa quindi un operatore pipeline (|) per inviare l'ID del processo al cmdlet Debug-Process .

Per altre informazioni sulla variabile automatica $PID, vedere about_Automatic_Variables.

Esempio 7: Collegare un debugger al processo specificato in più computer

PS C:\> Get-Process -ComputerName "Server01", "Server02" -Name "MyApp" | Debug-Process

Questo comando collega un debugger ai processi MyApp nei computer Server01 e Server02.

Il comando usa il cmdlet Get-Process per ottenere i processi MyApp nei computer Server01 e Server02. Usa un operatore pipeline per inviare i processi al cmdlet Debug-Process, che collega i debugger.

Esempio 8: Collegare un debugger a un processo che usa il parametro InputObject

PS C:\> $P = Get-Process "Windows PowerShell"
PS C:\> Debug-Process -InputObject $P

Questo comando collega un debugger ai processi Windows PowerShell nel computer locale.

Il primo comando usa il cmdlet Get-Process per ottenere i processi Windows PowerShell nel computer. Salva l'oggetto processo risultante nella variabile denominata $P.

Il secondo comando usa il parametro InputObject del cmdlet Debug-Process per inviare l'oggetto processo nella variabile $P.

Parametri

-Confirm

Richiede la conferma dell'utente prima di eseguire il cmdlet.

Type:SwitchParameter
Aliases:cf
Position:Named
Default value:False
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Id

Specifica gli ID dei processi di cui eseguire il debug. Il nome del parametro ID è facoltativo.

Per trovare l'ID processo di un processo, digitare Get-Process.

Type:Int32[]
Aliases:PID, ProcessId
Position:0
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-InputObject

Specifica gli oggetti processo che rappresentano i processi di cui eseguire il debug. Immettere una variabile contenente gli oggetti processo o un comando che ottiene gli oggetti processo, ad esempio il cmdlet Get-Process. È anche possibile inviare tramite pipe oggetti di elaborazione a questo cmdlet.

Type:Process[]
Position:Named
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-Name

Specifica i nomi dei processi di cui eseguire il debug. Se sono presenti più processi con lo stesso nome, questo cmdlet collega un debugger a tutti i processi con tale nome. Il parametro Name è facoltativo.

Type:String[]
Aliases:ProcessName
Position:0
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-WhatIf

Mostra l'esito in caso di esecuzione del cmdlet. Il cmdlet non viene eseguito.

Type:SwitchParameter
Aliases:wi
Position:Named
Default value:False
Required:False
Accept pipeline input:False
Accept wildcard characters:False

Input

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

È possibile inviare tramite pipe un ID processo (Int32), un oggetto processo (System.Diagnostics.Process) o un nome di processo (String) a questo cmdlet.

Output

None

Questo cmdlet non genera alcun output.

Note

  • Questo cmdlet usa il metodo AttachDebugger della classe Win32_Process di Strumentazione gestione Windows (WMI). Per altre informazioni su questo metodo, vedere Metodo AttachDebugger in MSDN Library.