Debug-Process
로컬 컴퓨터에서 실행되는 하나 이상의 프로세스를 디버그합니다.
Syntax
Debug-Process
[-Name] <String[]>
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Debug-Process
[-Id] <Int32[]>
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Debug-Process
-InputObject <Process[]>
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
cmdlet은 Debug-Process
로컬 컴퓨터에서 실행 중인 하나 이상의 프로세스에 디버거를 연결합니다.
프로세스 이름 또는 프로세스 ID(PID)로 프로세스를 지정하거나 프로세스 개체를 이 cmdlet으로 파이프할 수 있습니다.
이 cmdlet은 현재 프로세스에 등록된 디버거를 연결합니다. 이 cmdlet을 사용하기 전에 디버거가 다운로드되고 올바르게 구성되었는지 확인합니다.
예제
예제 1: 컴퓨터의 프로세스에 디버거 연결
PS C:\> Debug-Process -Name "Windows Powershell"
이 명령은 컴퓨터의 PowerShell 프로세스에 디버거를 연결합니다.
예제 2: 지정된 문자열로 시작하는 모든 프로세스에 디버거 연결
PS C:\> Debug-Process -Name "SQL*"
이 명령은 SQL로 시작하는 이름이 있는 모든 프로세스에 디버거를 연결합니다.
예제 3: 여러 프로세스에 디버거 연결
PS C:\> Debug-Process "Winlogon", "Explorer", "Outlook"
이 명령은 Winlogon, Explorer 및 Outlook 프로세스에 디버거를 연결합니다.
예제 4: 여러 프로세스 ID에 디버거 연결
PS C:\> Debug-Process -Id 1132, 2028
이 명령은 프로세스 ID 1132 및 2028이 있는 프로세스에 디버거를 연결합니다.
예제 5: Get-Process를 사용하여 프로세스를 가져와서 디버거를 연결합니다.
PS C:\> Get-Process "Windows PowerShell" | Debug-Process
이 명령은 컴퓨터의 PowerShell 프로세스에 디버거를 연결합니다. cmdlet을 Get-Process
사용하여 컴퓨터에서 PowerShell 프로세스를 가져와 파이프라인 연산자(|
)를 사용하여 프로세스를 cmdlet으로 Debug-Process
보냅니다.
특정 PowerShell 프로세스를 지정하려면 의 Get-Process
ID 매개 변수를 사용합니다.
예제 6: 로컬 컴퓨터의 현재 프로세스에 디버거 연결
PS C:\> $PID | Debug-Process
이 명령은 컴퓨터의 현재 PowerShell 프로세스에 디버거를 연결합니다.
이 명령은 현재 PowerShell 프로세스의 프로세스 ID를 포함하는 자동 변수를 사용합니다 $PID
. 그런 다음 파이프라인 연산자(|
)를 사용하여 프로세스 ID를 cmdlet으로 Debug-Process
보냅니다.
자동 변수에 대한 $PID
자세한 내용은 about_Automatic_Variables 참조하세요.
예제 7: InputObject 매개 변수를 사용하는 프로세스에 디버거 연결
PS C:\> $P = Get-Process "Windows PowerShell"
PS C:\> Debug-Process -InputObject $P
이 명령은 로컬 컴퓨터의 PowerShell 프로세스에 디버거를 연결합니다.
첫 번째 명령은 cmdlet을 Get-Process
사용하여 컴퓨터에서 PowerShell 프로세스를 가져옵니다. 결과 프로세스 개체를 명명 $P
된 변수에 저장합니다.
두 번째 명령은 cmdlet의 Debug-Process
InputObject 매개 변수를 사용하여 변수에 프로세스 개체를 $P
제출합니다.
매개 변수
-Confirm
cmdlet을 실행하기 전에 확인 메시지가 표시됩니다.
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Id
디버그할 프로세스의 프로세스 ID를 지정합니다. ID 매개 변수 이름은 선택 사항입니다.
프로세스의 프로세스 ID를 찾으려면 .를 입력합니다 Get-Process
.
Type: | Int32[] |
Aliases: | PID, ProcessId |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-InputObject
디버그할 프로세스를 나타내는 프로세스 개체를 지정합니다. 프로세스 개체 또는 cmdlet과 같은 프로세스 개체를 가져오는 명령이 포함된 변수를 Get-Process
입력합니다. 프로세스 개체를 이 cmdlet으로 파이프할 수도 있습니다.
Type: | Process[] |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Name
디버그할 프로세스의 이름을 지정합니다. 이름이 같은 프로세스가 두 개 이상 있는 경우 이 cmdlet은 해당 이름의 모든 프로세스에 디버거를 연결합니다. Name 매개 변수는 선택 사항입니다.
Type: | String[] |
Aliases: | ProcessName |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-WhatIf
cmdlet이 실행될 경우 결과 동작을 표시합니다. cmdlet이 실행되지 않습니다.
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
입력
프로세스 ID를 이 cmdlet으로 파이프할 수 있습니다.
프로세스 개체를 이 cmdlet으로 파이프할 수 있습니다.
프로세스 이름을 이 cmdlet으로 파이프할 수 있습니다.
출력
None
이 cmdlet은 출력을 반환하지 않습니다.
참고
이 cmdlet은 WMI(Windows Management Instrumentation) Win32_Process 클래스의 AttachDebugger 메서드를 사용합니다. 이 메서드 에 대한 자세한 내용은 MSDN 라이브러리의 AttachDebugger 메서드 를 참조하세요.
관련 링크
PowerShell
피드백
https://aka.ms/ContentUserFeedback
출시 예정: 2024년 내내 콘텐츠에 대한 피드백 메커니즘으로 GitHub 문제를 단계적으로 폐지하고 이를 새로운 피드백 시스템으로 바꿀 예정입니다. 자세한 내용은 다음을 참조하세요.다음에 대한 사용자 의견 제출 및 보기