Stop-Process
실행 중인 하나 이상의 프로세스를 중지합니다.
구문
Stop-Process [-Id] <Int32[]> [-Force] [-PassThru] [-Confirm] [-WhatIf] [<CommonParameters>]
Stop-Process -InputObject <Process[]> [-Force] [-PassThru] [-Confirm] [-WhatIf] [<CommonParameters>]
Stop-Process -Name <string[]> [-Force] [-PassThru] [-Confirm] [-WhatIf] [<CommonParameters>]
설명
Stop-Process cmdlet은 실행 중인 하나 이상의 프로세스를 중지합니다. 또한 프로세스 이름 또는 프로세스 ID(PID)로 프로세스를 지정하거나 프로세스 개체를 Stop-Process로 전달할 수 있습니다. Stop-Process는 로컬 컴퓨터에서 실행 중인 프로세스에서만 작동합니다.
Windows Vista 이상에서 현재 사용자가 소유하지 않은 프로세스를 종료하려면 "관리자 권한으로 실행" 옵션을 사용하여 Windows PowerShell을 시작해야 합니다. 또한 Force 매개 변수를 사용하지 않으면 확인 메시지가 나타납니다.
매개 변수
-Force
확인 메시지 없이 지정된 프로세스를 중지합니다. 기본적으로 Stop-Process는 현재 사용자가 소유하지 않은 프로세스를 중지하기 전에 확인 메시지를 표시합니다.
프로세스의 소유자를 찾으려면 Get-WmiMethod cmdlet을 사용하여 프로세스를 나타내는 Win32_Process 개체를 가져온 다음 개체의 GetOwner 메서드를 사용합니다.
필수 여부 |
false |
위치 |
named |
기본값 |
False |
파이프라인 입력 적용 여부 |
false |
와일드카드 문자 적용 여부 |
false |
-Id <Int32[]>
중지할 프로세스의 프로세스 ID를 지정합니다. 여러 ID를 지정하려면 쉼표를 사용하여 ID를 구분합니다. 프로세스의 PID를 찾으려면 "Get-Process"를 입력합니다. 매개 변수 이름("Id")은 선택 사항입니다.
필수 여부 |
true |
위치 |
1 |
기본값 |
|
파이프라인 입력 적용 여부 |
true (ByPropertyName) |
와일드카드 문자 적용 여부 |
false |
-InputObject <Process[]>
지정된 프로세스 개체에서 표시하는 프로세스를 중지합니다. 개체가 포함된 변수를 입력하거나 개체를 가져오는 명령 또는 식을 입력하십시오.
필수 여부 |
true |
위치 |
named |
기본값 |
|
파이프라인 입력 적용 여부 |
true (ByValue) |
와일드카드 문자 적용 여부 |
false |
-Name <string[]>
중지할 프로세스의 프로세스 이름을 지정합니다. 쉼표로 구분된 여러 프로세스 이름을 입력하거나 와일드카드 문자를 사용할 수 있습니다.
필수 여부 |
true |
위치 |
named |
기본값 |
|
파이프라인 입력 적용 여부 |
true (ByPropertyName) |
와일드카드 문자 적용 여부 |
false |
-PassThru
프로세스를 나타내는 개체를 반환합니다. 기본적으로 이 cmdlet에서는 출력을 생성하지 않습니다.
필수 여부 |
false |
위치 |
named |
기본값 |
|
파이프라인 입력 적용 여부 |
false |
와일드카드 문자 적용 여부 |
false |
-Confirm
명령을 실행하기 전에 확인 메시지를 표시합니다.
필수 여부 |
false |
위치 |
named |
기본값 |
|
파이프라인 입력 적용 여부 |
false |
와일드카드 문자 적용 여부 |
false |
-WhatIf
명령을 실제로 실행하지 않고도 명령이 실행될 경우 발생할 수 있는 현상을 설명합니다.
필수 여부 |
false |
위치 |
named |
기본값 |
|
파이프라인 입력 적용 여부 |
false |
와일드카드 문자 적용 여부 |
false |
<CommonParameters>
이 cmdlet은 -Verbose, -Debug, -ErrorAction, -ErrorVariable, -OutBuffer, -OutVariable 등의 일반 매개 변수를 지원합니다. 자세한 내용은 about_commonparameters.
입력 및 출력
입력 유형은 cmdlet으로 파이프할 수 있는 개체의 유형입니다. 반환 유형은 cmdlet에서 반환되는 개체의 유형입니다.
입력 |
System.Diagnostics.Process 프로세스 개체를 Stop-Process로 파이프할 수 있습니다. |
출력 |
없음 또는 System.Diagnostics.Process PassThru 매개 변수를 사용하는 경우 Stop-Process는 중지된 프로세스를 나타내는 System.Diagnostics.Process 개체를 반환합니다. 그렇지 않으면 아무 출력도 생성하지 않습니다. |
참고
또한 해당 기본 제공 별칭("kill" 및 "spps")으로 Stop-Process를 참조할 수 있습니다. 자세한 내용은 about_Aliases를 참조하십시오.
Windows PowerShell에서는 WMI(Windows Management Instrumentation) Win32_Process 개체의 속성 및 메서드도 사용할 수 있습니다. 자세한 내용은 Get-WmiObject 및 WMI SDK를 참조하십시오.
프로세스를 중지하면 해당 프로세스에 종속된 다른 프로세스와 서비스도 함께 중지될 수 있습니다. 극히 드문 경우이지만 프로세스를 중지하면 Windows가 중지될 수도 있습니다.
예 1
C:\PS>stop-process -name notepad
설명
-----------
이 명령은 컴퓨터의 Notepad 프로세스의 모든 인스턴스를 중지합니다. 각 Notepad 인스턴스는 고유 프로세스에서 실행됩니다. 이 명령은 Name 매개 변수를 사용하여 프로세스를 지정하며 모두 동일한 이름을 갖습니다. ID 매개 변수를 사용하여 동일한 프로세스를 중지하는 경우 각 Notepad 인스턴스의 프로세스 ID를 나열해야 합니다.
예 2
C:\PS>stop-process -id 3952 -confirm -passthru
Confirm
Are you sure you want to perform this action?
Performing operation "Stop-Process" on Target "notepad (3952)".
[Y] Yes [A] Yes to All [N] No [L] No to All [S] Suspend [?] Help
(default is "Y"):y
Handles NPM(K) PM(K) WS(K) VM(M) CPU(s) Id ProcessName
------- ------ ----- ----- ----- ------ -- -----------
41 2 996 3212 31 3952 notepad
설명
-----------
이 명령은 Notepad 프로세스의 특정 인스턴스를 중지합니다. 먼저 프로세스 ID, 3952를 사용하여 프로세스를 식별합니다. Confirm 매개 변수는 Windows PowerShell이 프로세스를 중지하기 전에 사용자에게 확인 메시지를 표시하도록 지시합니다. 이 메시지에는 프로세스 이름 및 해당 ID가 포함되어 있으므로 유용한 정보를 제공합니다. PassThru 매개 변수는 화면 표시를 위해 프로세스 개체를 포맷터로 전달합니다. 이 매개 변수가 없으면 Stop-Process 명령 후에 아무 것도 표시되지 않습니다.
예 3
C:\PS>calc
c:\PS>$p = get-process calc
c:\PS>stop-process -inputobject $p
c:\PS>get-process | where-object {$_.HasExited}
설명
-----------
이 명령은 Calc 프로세스를 시작 및 중지한 다음 중지된 프로세스를 검색합니다.
첫 번째 명령("calc")은 계산기의 인스턴스를 시작합니다. 두 번째 명령 ("$p = get-process calc")은 Get-Process cmdlet을 사용하여 Calc 프로세스를 나타내는 개체를 가져와서 $p 변수에 저장합니다. 세 번째 명령("stop-process -inputobject $p")은 Stop-Process cmdlet을 사용하여 Calc 프로세스를 중지합니다. 이 명령은 InputObject 매개 변수를 사용하여 개체를 Stop-Process로 전달합니다.
마지막 명령은 이전에 실행되었지만 지금은 중지된 컴퓨터의 모든 프로세스를 가져옵니다. 이 명령은 Get-Process cmdlet을 사용하여 컴퓨터의 모든 프로세스를 가져옵니다. 파이프라인 연산자(|)는 Where-Object cmdlet으로 결과를 전달합니다. Where-Object cmdlet은 HasExited 속성 값이 TRUE인 프로세스를 선택합니다. HasExited는 프로세스 개체의 속성 중 하나입니다. 속성을 모두 찾으려면 "get-process | get-member"를 입력하십시오.
예 4
C:\PS>get-process lsass | stop-process
Stop-Process : Cannot stop process 'lsass (596)' because of the following error: Access is denied
At line:1 char:34
+ get-process lsass | stop-process <<<<
[ADMIN]: C:\PS> get-process lsass | stop-process
Warning!
Are you sure you want to perform this action?
Performing operation 'Stop-Process' on Target 'lsass(596)'
[Y] Yes [A] Yes to All [N] No [L] No to All [S] Suspend [?] Help (default is "Y"):
[ADMIN]: C:\PS> get-process lsass | stop-process -force
[ADMIN]: C:\PS>
설명
-----------
이들 명령은 Force 매개 변수를 사용하여 사용자가 소유하지 않은 프로세스를 중지하는 효과를 보여 줍니다.
첫 번째 명령은 Get-Process cmdlet을 사용하여 Lsass 프로세스를 가져온 다음 파이프라인 연산자를 사용하여 결과를 Stop-Process cmdlet으로 보내 중지합니다. 이 프로세스는 컴퓨터의 Administrator 그룹 멤버만 중지할 수 있으므로 샘플 출력에서처럼 첫 번째 명령은 "액세스가 거부되었습니다." 메시지와 함께 실패합니다.
Windows PowerShell을 "관리자 권한으로 실행" 옵션으로 열고 명령을 반복하면 확인 메시지가 나타납니다.
두 번째 명령은 Force 매개 변수를 사용하여 메시지가 나타나지 않게 합니다. 그 결과 확인 메시지 없이 프로세스가 중지됩니다.
참고 항목
개념
Get-Process
Start-Process
Stop-Process
Wait-Process
Debug-Process