Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 4개 있습니다.)
Windows: 146. PowerShell로 원격 프로세스(EXE, BAT) 실행하는 방법
; https://www.sysnet.pe.kr/2/0/11450

개발 환경 구성: 738. PowerShell - 원격 호출 시 "powershell.exe"가 아닌 "pwsh.exe" 환경으로 명령어를 실행하는 방법
; https://www.sysnet.pe.kr/2/0/13858

닷넷: 2325. C# - PowerShell과 연동하는 방법
; https://www.sysnet.pe.kr/2/0/13892

닷넷: 2326. C# - PowerShell과 연동하는 방법 (두 번째 이야기)
; https://www.sysnet.pe.kr/2/0/13897




PowerShell - 원격 호출 시 "powershell.exe"가 아닌 "pwsh.exe" 환경으로 명령어를 실행하는 방법

예를 하나 들어 볼까요? ^^ Windows Server 2012의 경우 설치된 PowerShell 버전이 4.0인데요, 이 버전에는 "Expand-Archive" 명령어가 없습니다.

c:\temp> powershell -command "Expand-Archive c:\temp\test.zip c:\temp\testdir"
Expand-Archive : The term 'Expand-Archive' is not recognized as the name of a cmdlet, function, script file, or operable program. Check the spelling of the name, or if a path was included, verify that the path is correct and try again.
At line:1 char:1
+ Expand-Archive c:\temp\test.zip c:\temp\testdir
+ ~~~~~~~~~~~~~~
    + CategoryInfo          : ObjectNotFound: (Expand-Archive:String) [], CommandNotFoundException
    + FullyQualifiedErrorId : CommandNotFoundException

이러한 제약을 극복하기 위해 별도로 배포되는 PowerShell 7을,

PowerShell - Releases
; https://github.com/PowerShell/PowerShell/releases

PowerShell-7.4.6-win-x64.msi
; https://github.com/PowerShell/PowerShell/releases/download/v7.4.6/PowerShell-7.4.6-win-x64.msi

설치하게 되면 Windows Server 2012라고 해도 다음과 같이 Expand-Archive 명령어를 사용할 수 있습니다.

c:\temp> where pwsh
C:\Program Files\PowerShell\7\pwsh.exe

c:\temp> pwsh.exe -Command "Expand-Archive c:\temp\test.zip c:\temp\testdir"




자, 그런데 원격 호출을 하는 경우라면 상황이 조금 다릅니다. 우선, PowerShell은 다양한 원격 호출 방법이 있는데요,

Windows PowerShell remoting without configuration
; https://learn.microsoft.com/en-us/powershell/scripting/security/remoting/running-remote-commands#windows-powershell-remoting-without-configuration

Windows PowerShell remoting
; https://learn.microsoft.com/en-us/powershell/scripting/security/remoting/running-remote-commands#windows-windows-powershell-remoting

Run a Remote Command
; https://learn.microsoft.com/en-us/powershell/scripting/security/remoting/running-remote-commands#run-a-remote-command

이 중에서 테스트가 쉬운 Invoke-Command로 예를 들어 보겠습니다. 가령, 다른 머신에서 Windows Server 2012 R2 머신으로 원격 호출을 하고 싶다면,

// Windows 11 머신에서 Windows Server 2012 R2 머신으로 원격 호출

C:\temp> powershell -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {Get-UICulture}"

LCID             Name             DisplayName                                PSComputerName
----             ----             -----------                                --------------
1033             en-US            English (United States)                    win2012r2

이런 식으로 -ComputerName 옵션을 추가하기만 하면 됩니다. 하지만 여기서 문제는, 저렇게 실행한 원격 호출은 대상 머신에 기본 설치된 PowerShell 4.0을 사용하므로, Expand-Archive 명령어 등을 사용하게 되는 경우라면 오류가 발생합니다.

C:\temp> powershell -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {Expand-Archive c:\temp\test.zip c:\temp\testdir}"
The term 'Expand-Archive' is not recognized as the name of a cmdlet, function, script file, or operable program. Check
the spelling of the name, or if a path was included, verify that the path is correct and try again.
    + CategoryInfo          : ObjectNotFound: (Expand-Archive:String) [], CommandNotFoundException
    + FullyQualifiedErrorId : CommandNotFoundException
    + PSComputerName        : win2012r2

설령, 호출하는 측의 머신에 PowerShell 7을 설치해 그걸로 원격 호출을 하더라도 결과는 마찬가지인데요,

// 호출 측 Windows 11 머신에 pwsh를 설치

C:\temp> "C:\Program Files\PowerShell\7\pwsh.exe" -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {Expand-Archive c:\temp\test.zip c:\temp\testdir}"
ObjectNotFound: The term 'Expand-Archive' is not recognized as the name of a cmdlet, function, script file, or operable program. Check the spelling of the name, or if a path was included, verify that the path is correct and try again.

어차피 원격 컴퓨터의 호스팅 환경은 여전히 기본 설치된 PowerShell이기 때문입니다.

C:\temp> pwsh.exe -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {$PSVersionTable.PSVersion}"

Major  Minor  Build  Revision PSComputerName
-----  -----  -----  -------- --------------
4      0      -1     -1       win2012r2




사실 PowerShell의 원격 호출 시 대상 머신에서 이에 대한 요청을 처리하는 구성 요소는 WinRM이라고 알려진 "Windows Remote Management (WS-Management)" NT 서비스입니다.

C:\temp> pwsh.exe -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {$PSSessionApplicationName}"
wsman

따라서 원격 호출의 대상 머신에서 "powershell.exe"가 아닌 "pwsh.exe" 환경에서 명령어를 실행하려면 WinRm으로 하여금 pwsh.exe를 사용하도록 알려야 하는데요, 이에 대해서는 WinRM 측에서 이미 관련 설정을 제공하고 있습니다.

how to get winrm to use powershell 7 for remote sessions by default
; https://stackoverflow.com/questions/60561852/how-to-get-winrm-to-use-powershell-7-for-remote-sessions-by-default

위의 글에 따르면, 기본 호스팅 환경을 다음과 같이 확인할 수 있고,

c:\temp> pwsh.exe -c "Invoke-Command -ComputerName win2012r2 -ScriptBlock {$PSSessionConfigurationName}"
http://schemas.microsoft.com/powershell/Microsoft.PowerShell

"Microsoft.PowerShell"로 식별되는 호스팅 환경이 무엇인지 Get-PSSessionConfiguration 명령어로 확인할 수 있습니다.

// 대상 머신에서 실행 (이 글의 경우, Windows Server 2012 R2 머신에서 실행)
// 관리자 권한

c:\temp> pwsh -c "Get-PSSessionConfiguration"

Name          : PowerShell.7
PSVersion     : 7.4
StartupScript :
RunAsUser     :
Permission    : NT AUTHORITY\INTERACTIVE AccessAllowed, BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

Name          : PowerShell.7.4.6
PSVersion     : 7.4
StartupScript :
RunAsUser     :
Permission    : NT AUTHORITY\INTERACTIVE AccessAllowed, BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed


// 또는 이렇게!

c:\temp> powershell -c "Get-PSSessionConfiguration"


Name          : microsoft.powershell
PSVersion     : 4.0
StartupScript :
RunAsUser     :
Permission    : BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

Name          : microsoft.powershell.workflow
PSVersion     : 4.0
StartupScript :
RunAsUser     :
Permission    : BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

Name          : microsoft.powershell32
PSVersion     : 4.0
StartupScript :
RunAsUser     :
Permission    : BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

Name          : microsoft.windows.servermanagerworkflows
PSVersion     : 3.0
StartupScript :
RunAsUser     :
Permission    : NT AUTHORITY\INTERACTIVE AccessAllowed, BUILTIN\Administrators AccessAllowed

Name          : PowerShell.7
PSVersion     : 7.4
StartupScript :
RunAsUser     :
Permission    : NT AUTHORITY\INTERACTIVE AccessAllowed, BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

Name          : PowerShell.7.4.6
PSVersion     : 7.4
StartupScript :
RunAsUser     :
Permission    : NT AUTHORITY\INTERACTIVE AccessAllowed, BUILTIN\Administrators AccessAllowed, BUILTIN\Remote Management Users AccessAllowed

보는 바와 같이 "microsoft.powershell"은 4.0 버전의 PowerShell을 식별하는 Name 값입니다. 따라서, 우리는 저 식별자를 우리가 원하는 pwsh.exe 환경으로 바꾸면 되기 때문에 "PowerShell.7" 또는 "PowerShell.7.4.6"을 선택할 수 있습니다. 그리고 그 식별자를 Invoke-Command의 ConfigurationName 옵션에 지정하면,

c:\temp> pwsh.exe -c "Invoke-Command -ConfigurationName Powershell.7 -ComputerName win2012r2 -ScriptBlock {$PSVersionTable.PSVersion}"

Major  Minor  Patch  PreReleaseLabel BuildLabel  PSComputerName
-----  -----  -----  --------------- ----------  --------------
7      4      6                                  win2012r2

이렇게 원격 호출 시 대상 머신에서 호스팅하는 PowerShell 환경을 "pwsh.exe"로 변경할 수 있습니다. 그렇다면 당연히 Expand-Archive 명령어도 사용할 수 있겠죠? ^^

c:\temp> pwsh.exe -c "Invoke-Command -ConfigurationName Powershell.7 -ComputerName win2012r2 -ScriptBlock {Expand-Archive c:\temp\test.zip c:\temp\testdir}"

// 또는,

c:\temp> powershell.exe -c "Invoke-Command -ConfigurationName Powershell.7 -ComputerName win2012r2 -ScriptBlock {Expand-Archive c:\temp\test.zip c:\temp\testdir}"




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/8/2025]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...
NoWriterDateCnt.TitleFile(s)
12812정성태8/28/202116601.NET Framework: 1108. C# 10 - (10) 개선된 #line 지시자
12811정성태8/27/202116479Linux: 44. 윈도우 개발자를 위한 리눅스 fork 동작 방식 설명 (파이썬 코드)
12810정성태8/27/202115492.NET Framework: 1107. .NET Core/5+에서 동적 컴파일한 C# 코드를 (Breakpoint도 활용하며) 디버깅하는 방법 - #line 지시자파일 다운로드1
12809정성태8/26/202115455.NET Framework: 1106. .NET Core/5+에서 C# 코드를 동적으로 컴파일/사용하는 방법 [1]파일 다운로드1
12808정성태8/25/202117109오류 유형: 758. go: ...: missing go.sum entry; to add it: go mod download ...
12807정성태8/25/202117878.NET Framework: 1105. C# 10 - (9) 비동기 메서드가 사용할 AsyncMethodBuilder 선택 가능파일 다운로드1
12806정성태8/24/202114427개발 환경 구성: 601. PyCharm - 다중 프로세스 디버깅 방법
12805정성태8/24/202116136.NET Framework: 1104. C# 10 - (8) 분해 구문에서 기존 변수의 재사용 가능파일 다운로드1
12804정성태8/24/202116303.NET Framework: 1103. C# 10 - (7) Source Generator V2 APIs
12803정성태8/23/202116809개발 환경 구성: 600. pip cache 디렉터리 옮기는 방법
12802정성태8/23/202117230.NET Framework: 1102. .NET Conf Mini 21.08 - WinUI 3 따라해 보기 [1]
12801정성태8/23/202116817.NET Framework: 1101. C# 10 - (6) record class 타입의 ToString 메서드를 sealed 처리 허용파일 다운로드1
12800정성태8/22/202117192개발 환경 구성: 599. PyCharm - (반대로) 원격 프로세스가 PyCharm에 디버그 연결하는 방법
12799정성태8/22/202117487.NET Framework: 1100. C# 10 - (5) 속성 패턴의 개선파일 다운로드1
12798정성태8/21/202118827개발 환경 구성: 598. PyCharm - 원격 프로세스를 디버그하는 방법
12797정성태8/21/202116200Windows: 197. TCP의 MSS(Maximum Segment Size) 크기는 고정된 것일까요?
12796정성태8/21/202117199.NET Framework: 1099. C# 10 - (4) 상수 문자열에 포맷 식 사용 가능파일 다운로드1
12795정성태8/20/202117514.NET Framework: 1098. .NET 6에 포함된 신규 BCL API - 스레드 관련
12794정성태8/20/202116883스크립트: 23. 파이썬 - WSGI를 만족하는 최소한의 구현 코드 및 PyCharm에서의 디버깅 방법 [1]
12793정성태8/20/202117684.NET Framework: 1097. C# 10 - (3) 개선된 변수 초기화 판정파일 다운로드1
12792정성태8/19/202118795.NET Framework: 1096. C# 10 - (2) 전역 네임스페이스 선언파일 다운로드1
12791정성태8/19/202115608.NET Framework: 1095. C# COM 개체를 C++에서 사용하는 예제 [3]파일 다운로드1
12790정성태8/18/202119550.NET Framework: 1094. C# 10 - (1) 구조체를 생성하는 record struct파일 다운로드1
12789정성태8/18/202118214개발 환경 구성: 597. PyCharm - 윈도우 환경에서 WSL을 이용해 파이썬 앱 개발/디버깅하는 방법
12788정성태8/17/202115753.NET Framework: 1093. C# - 인터페이스의 메서드가 다형성을 제공할까요? (virtual일까요?)파일 다운로드1
12787정성태8/17/202116140.NET Framework: 1092. (책 내용 수정) "4.5.1.4 인터페이스"의 "인터페이스와 다형성"
... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...