다음을 통해 공유


Set-PSBreakpoint

줄, 명령 또는 변수에 중단점을 설정합니다.

구문

Set-PSBreakpoint
   [-Action <ScriptBlock>]
   [[-Column] <Int32>]
   [-Line] <Int32[]>
   [-Script] <String[]>
   [-Runspace <Runspace>]
   [<CommonParameters>]
Set-PSBreakpoint
   [-Action <ScriptBlock>]
   -Command <String[]>
   [[-Script] <String[]>]
   [-Runspace <Runspace>]
   [<CommonParameters>]
Set-PSBreakpoint
   [-Action <ScriptBlock>]
   [[-Script] <String[]>]
   -Variable <String[]>
   [-Mode <VariableAccessMode>]
   [-Runspace <Runspace>]
   [<CommonParameters>]

Description

Set-PSBreakpoint cmdlet은 스크립트 또는 현재 세션의 명령 실행에서 중단점을 설정합니다. Set-PSBreakpoint 사용하여 스크립트를 실행하거나 명령을 실행하거나 디버깅하는 동안 다른 중단점에서 중지될 때 중단점을 설정할 수 있습니다.

Set-PSBreakpoint 원격 컴퓨터에서 중단점을 설정할 수 없습니다. 원격 컴퓨터에서 스크립트를 디버그하려면 스크립트를 로컬 컴퓨터에 복사한 다음 로컬로 디버그합니다.

Set-PSBreakpoint 명령은 다음 세 가지 유형의 중단점 중 하나를 만듭니다.

  • 줄 중단점 - 특정 선 및 열 좌표에서 중단점을 설정합니다.
  • 명령 중단점 - 명령 및 함수에 중단점을 설정합니다.
  • 변수 중단점 - 변수에 중단점을 설정합니다.

단일 Set-PSBreakpoint 명령에서 여러 줄, 명령 또는 변수에 중단점을 설정할 수 있지만 각 Set-PSBreakpoint 명령은 중단점의 한 유형만 설정합니다.

중단점에서 PowerShell은 일시적으로 실행을 중지하고 디버거를 제어합니다. 명령 프롬프트가 DBG\>변경되고 디버거 명령 집합을 사용할 수 있게 됩니다. 그러나 Action 매개 변수를 사용하여 중단점에 대한 조건이나 로깅 또는 진단과 같은 추가 작업을 수행하는 지침과 같은 대체 응답을 지정할 수 있습니다.

Set-PSBreakpoint cmdlet은 PowerShell 스크립트 디버깅을 위해 설계된 여러 cmdlet 중 하나입니다. PowerShell 디버거에 대한 자세한 내용은 about_Debuggers참조하세요.

예제

예제 1: 줄에 중단점 설정

다음은 Sample.ps1 스크립트의 줄 5에서 중단점을 설정하는 예제입니다. 스크립트가 실행되면 5줄이 실행되기 직전에 실행이 중지됩니다.

Set-PSBreakpoint -Script "sample.ps1" -Line 5

Column     : 0
Line       : 5
Action     :
Enabled    : True
HitCount   : 0
Id         : 0
Script     : C:\ps-test\sample.ps1
ScriptName : C:\ps-test\sample.ps1

줄 번호별로 새 중단점을 설정하면 Set-PSBreakpoint cmdlet은 중단점 ID 및 적중 횟수를 포함하는 줄 중단점 개체(System.Management.Automation.LineBreakpoint)를 생성합니다.

예제 2: 함수에 중단점 설정

이 예제에서는 Sample.ps1 cmdlet의 Increment 함수에 명령 중단점을 만듭니다. 스크립트는 지정된 함수에 대한 각 호출 바로 전에 실행을 중지합니다.

Set-PSBreakpoint -Command "Increment" -Script "sample.ps1"

Command    : Increment
Action     :
Enabled    : True
HitCount   : 0
Id         : 1
Script     : C:\ps-test\sample.ps1
ScriptName : C:\ps-test\sample.ps1

결과는 명령 중단점 개체입니다. 스크립트를 실행하기 전에 HitCount 속성의 값은 0입니다.

예제 3: 변수에 중단점 설정

다음은 Sample.ps1 스크립트의 Server 변수에 중단점을 설정하는 예제입니다. Mode 매개 변수와 ReadWrite 값을 사용하여 변수 값을 읽고 값이 변경되기 직전에 실행을 중지합니다.

Set-PSBreakpoint -Script "sample.ps1" -Variable "Server" -Mode ReadWrite

예제 4: 지정된 텍스트로 시작하는 모든 명령에 중단점 설정

다음은 Write-Host같은 "쓰기"로 시작하는 Sample.ps1 스크립트의 모든 명령에 중단점을 설정하는 예제입니다.

Set-PSBreakpoint -Script Sample.ps1 -Command "write*"

예제 5: 변수 값에 따라 중단점 설정

다음은 $Disk 변수 값이 2보다 큰 경우에만 Test.ps1 스크립트의 DiskTest 함수에서 실행을 중지하는 예제입니다.

Set-PSBreakpoint -Script "test.ps1" -Command "DiskTest" -Action { if ($Disk -gt 2) { break } }

Action 값은 함수에서 $Disk 변수의 값을 테스트하는 스크립트 블록입니다.

이 작업은 조건이 충족되는 경우 break 키워드를 사용하여 실행을 중지합니다. 대체(및 기본값)는 계속.

예제 6: 함수에 중단점 설정

다음은 CheckLog 함수에 중단점을 설정하는 예제입니다. 명령은 스크립트를 지정하지 않으므로 중단점은 현재 세션에서 실행되는 모든 항목에 대해 설정됩니다. 디버거는 함수가 선언될 때가 아니라 호출될 때 중단됩니다.

PS> Set-PSBreakpoint -Command "checklog"
Id       : 0
Command  : checklog
Enabled  : True
HitCount : 0
Action   :

function CheckLog {
>> get-eventlog -log Application |
>> where {($_.source -like "TestApp") -and ($_.Message -like "*failed*")}
>>}
>>
PS> Checklog
DEBUG: Hit breakpoint(s)
DEBUG:  Function breakpoint on 'prompt:Checklog'

예제 7: 여러 줄에 중단점 설정

다음은 Sample.ps1 스크립트에서 세 줄 중단점을 설정하는 예제입니다. 스크립트에 지정된 각 줄의 열 2에 하나의 중단점을 설정합니다. Action 매개 변수에 지정된 작업은 모든 중단점에 적용됩니다.

PS C:\> Set-PSBreakpoint -Script "sample.ps1" -Line 1, 14, 19 -Column 2 -Action {&(log.ps1)}

Column     : 2
Line       : 1
Action     :
Enabled    : True
HitCount   : 0
Id         : 6
Script     : C:\ps-test\sample.ps1
ScriptName : C:\ps-test\sample.ps1


Column     : 2
Line       : 14
Action     :
Enabled    : True
HitCount   : 0
Id         : 7
Script     : C:\ps-test\sample.ps1
ScriptName : C:\ps-test\sample.ps1


Column     : 2
Line       : 19
Action     :
Enabled    : True
HitCount   : 0
Id         : 8
Script     : C:\ps-test\sample.ps1
ScriptName : C:\ps-test\sample.ps1

예제 8: Runspace에서 중단점 설정

이 예제에서는 작업이 시작됩니다. runspace는 변수에 저장되고 Runspace 매개 변수를 사용하여 Set-PSBreakPoint 명령에 전달됩니다.

Start-Job -ScriptBlock {
    Start-Sleep -Seconds 10
}

$runspace = Get-Runspace -Id 1

Set-PSBreakpoint -Command Start-Sleep -Runspace $runspace

매개 변수

-Action

각 중단점에서 중단점이 중단되는 대신 실행되는 명령을 지정합니다. 명령이 포함된 스크립트 블록을 입력합니다. 이 매개 변수를 사용하여 조건부 중단점을 설정하거나 테스트 또는 로깅과 같은 다른 작업을 수행할 수 있습니다.

이 매개 변수를 생략하거나 작업이 지정되지 않은 경우 중단점에서 실행이 중지되고 디버거가 시작됩니다.

Action 매개 변수를 사용하면 작업 스크립트 블록이 각 중단점에서 실행됩니다. 스크립트 블록에 Break 키워드가 포함되어 있지 않으면 실행이 중지되지 않습니다. 스크립트 블록에서 Continue 키워드를 사용하는 경우 다음 중단점까지 실행이 다시 시작됩니다.

자세한 내용은 about_Script_Blocks, about_Breakabout_Continue참조하세요.

형식:ScriptBlock
Position:Named
Default value:None
필수:False
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Column

실행이 중지되는 스크립트 파일의 열 번호를 지정합니다. 열 번호를 하나만 입력합니다. 기본값은 열 1입니다.

열 값은 중단점을 지정하기 위해 Line 매개 변수의 값과 함께 사용됩니다. Line 매개 변수가 여러 줄을 지정하는 경우 Column 매개 변수는 지정된 각 줄의 지정된 열에 중단점을 설정합니다. PowerShell은 지정된 줄 및 열 위치에 있는 문자를 포함하는 문 또는 식 앞에 실행을 중지합니다.

열은 열 번호 1(0이 아님)부터 왼쪽 위 여백에서 계산됩니다. 스크립트에 없는 열을 지정하면 오류가 선언되지 않지만 중단점은 실행되지 않습니다.

형식:Int32
Position:2
Default value:1
필수:False
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Command

명령 중단점을 설정합니다. Get-Process같은 cmdlet 이름 또는 함수 이름을 입력합니다. 와일드카드가 허용됩니다.

각 명령의 각 인스턴스가 실행되기 직전에 실행이 중지됩니다. 명령이 함수인 경우 함수가 호출되고 각 BEGIN, PROCESS 및 END 섹션에서 실행이 중지됩니다.

형식:String[]
별칭:C
Position:Named
Default value:None
필수:True
파이프라인 입력 허용:False
와일드카드 문자 허용:True

-Line

스크립트에서 줄 중단점을 설정합니다. 하나 이상의 줄 번호를 쉼표로 구분하여 입력합니다. PowerShell은 지정된 각 줄에서 시작되는 문을 실행하기 직전에 중지됩니다.

줄은 줄 번호 1(0이 아님)으로 시작하는 스크립트 파일의 왼쪽 위 여백에서 계산됩니다. 빈 줄을 지정하면 빈 줄이 아닌 다음 줄 앞에 실행이 중지됩니다. 줄이 범위를 벗어나면 중단점이 적중되지 않습니다.

형식:Int32[]
Position:1
Default value:None
필수:True
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Mode

변수 중단점을 트리거하는 액세스 모드를 지정합니다. 기본값은 쓰기.

이 매개 변수는 변수 매개 변수가 명령에 사용되는 경우에만 유효합니다. 이 모드는 명령에 설정된 모든 중단점에 적용됩니다. 이 매개 변수에 허용되는 값은 다음과 같습니다.

  • 쓰기 - 새 값이 변수에 기록되기 직전에 실행을 중지합니다.
  • 읽기 - 변수를 읽을 때, 즉 값에 액세스할 때 할당, 표시 또는 사용 시 실행을 중지합니다. 읽기 모드에서는 변수 값이 변경되면 실행이 중지되지 않습니다.
  • ReadWrite - 변수를 읽거나 쓸 때 실행을 중지합니다.
형식:VariableAccessMode
허용되는 값:Read, Write, ReadWrite
Position:Named
Default value:None
필수:False
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Runspace

지정된 runspace에서 중단점과 상호 작용할 수 있도록 Runspace 개체의 ID를 지정합니다.

이 매개 변수는 PowerShell 7.2에 추가되었습니다.

형식:Runspace
Position:Named
Default value:None
필수:False
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Script

이 cmdlet이 중단점을 설정하는 스크립트 파일의 배열을 지정합니다. 하나 이상의 스크립트 파일의 경로 및 파일 이름을 입력합니다. 파일이 현재 디렉터리에 있는 경우 경로를 생략할 수 있습니다. 와일드카드가 허용됩니다.

기본적으로 변수 중단점 및 명령 중단점은 현재 세션에서 실행되는 모든 명령에 설정됩니다. 이 매개 변수는 줄 중단점을 설정할 때만 필요합니다.

형식:String[]
Position:0
Default value:None
필수:False
파이프라인 입력 허용:False
와일드카드 문자 허용:False

-Variable

이 cmdlet이 중단점을 설정하는 변수 배열을 지정합니다. 달러 기호($)가 없는 쉼표로 구분된 변수 목록을 입력합니다.

Mode 매개 변수를 사용하여 중단점을 트리거하는 액세스 모드를 결정합니다. 기본 모드인 Write는 새 값이 변수에 기록되기 직전에 실행을 중지합니다.

형식:String[]
별칭:V
Position:Named
Default value:None
필수:True
파이프라인 입력 허용:False
와일드카드 문자 허용:False

입력

None

개체를 이 cmdlet으로 파이프할 수 없습니다.

출력

CommandBreakpoint

LineBreakpoint

VariableBreakpoint

Set-PSBreakpoint 설정한 각 중단점을 나타내는 개체를 반환합니다.

참고

PowerShell에는 Set-PSBreakpoint다음과 같은 별칭이 포함되어 있습니다.

  • 모든 플랫폼:

    • sbp
  • Set-PSBreakpoint 원격 컴퓨터에서 중단점을 설정할 수 없습니다. 원격 컴퓨터에서 스크립트를 디버그하려면 스크립트를 로컬 컴퓨터에 복사한 다음 로컬로 디버그합니다.

  • 둘 이상의 줄, 명령 또는 변수에 중단점을 설정하면 Set-PSBreakpoint 각 항목에 대한 중단점 개체를 생성합니다.

  • 명령 프롬프트에서 함수 또는 변수에 중단점을 설정할 때 함수 또는 변수를 만들기 전이나 후에 중단점을 설정할 수 있습니다.