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

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...
NoWriterDateCnt.TitleFile(s)
13357정성태5/16/202315968.NET Framework: 2124. C# - Semantic Kernel의 Planner 사용 예제파일 다운로드1
13356정성태5/15/202318221DDK: 10. Device Driver 테스트 설치 관련 오류 (Code 37, Code 31) 및 인증서 관련 정리
13355정성태5/12/202316060.NET Framework: 2123. C# - Semantic Kernel의 ChatGPT 대화 구현 [1]파일 다운로드1
13354정성태5/12/202319004.NET Framework: 2122. C# - "Use Unicode UTF-8 for worldwide language support" 설정을 한 경우, 한글 입력이 '\0' 문자로 처리
13352정성태5/12/202317427.NET Framework: 2121. C# - Semantic Kernel의 대화 문맥 유지파일 다운로드1
13351정성태5/11/202318212VS.NET IDE: 185. Visual Studio - 원격 Docker container 내에 실행 중인 응용 프로그램에 대한 디버깅 [1]
13350정성태5/11/202317537오류 유형: 859. Windows Date and Time - Unable to continue. You do not have permission to perform this task
13349정성태5/11/202316824.NET Framework: 2120. C# - Semantic Kernel의 Skill과 Function 사용 예제 [1]파일 다운로드1
13348정성태5/10/202318819.NET Framework: 2119. C# - Semantic Kernel의 "Basic Loading of the Kernel" 예제
13347정성태5/10/202319043.NET Framework: 2118. C# - Semantic Kernel의 Prompt chaining 예제파일 다운로드1
13346정성태5/10/202319450오류 유형: 858. RDP 원격 환경과 로컬 PC 간의 Ctrl+C, Ctrl+V 복사가 안 되는 문제
13345정성태5/9/202320825.NET Framework: 2117. C# - (OpenAI 기반의) Microsoft Semantic Kernel을 이용한 자연어 처리 [1]파일 다운로드1
13344정성태5/9/202322973.NET Framework: 2116. C# - OpenAI API 사용 - 지원 모델 목록 [1]파일 다운로드1
13343정성태5/9/202320637디버깅 기술: 192. Windbg - Hyper-V VM으로 이더넷 원격 디버깅 연결하는 방법
13342정성태5/8/202316560.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
13341정성태5/8/202317253닷넷: 2114. C# 12 - 모든 형식의 별칭(Using aliases for any type)
13340정성태5/8/202316204오류 유형: 857. Microsoft.Data.SqlClient.SqlException - 0x80131904, 0x80131509
13339정성태5/6/202318822닷넷: 2113. C# 12 - 기본 생성자(Primary Constructors)
13338정성태5/6/202315938닷넷: 2112. C# 12 - 기본 람다 매개 변수파일 다운로드1
13337정성태5/5/202318991Linux: 59. dockerfile - docker exec로 container에 접속 시 자동으로 실행되는 코드 적용
13336정성태5/4/202317752.NET Framework: 2111. C# - 바이너리 출력 디렉터리와 연관된 csproj 설정
13335정성태4/30/202320259.NET Framework: 2110. C# - FFmpeg.AutoGen 라이브러리를 이용한 기본 프로젝트 구성 - Windows Forms파일 다운로드1
13334정성태4/29/202318821Windows: 250. Win32 C/C++ - Modal 메시지 루프 내에서 SetWindowsHookEx를 이용한 Thread 메시지 처리 방법
13333정성태4/28/202315398Windows: 249. Win32 C/C++ - 대화창 템플릿을 런타임에 코딩해서 사용파일 다운로드1
13332정성태4/27/202316054Windows: 248. Win32 C/C++ - 대화창을 위한 메시지 루프 사용자 정의파일 다운로드1
13331정성태4/27/202315598오류 유형: 856. dockerfile - 구 버전의 .NET Core 이미지 사용 시 apt update 오류
... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...