Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 2개 있습니다.)
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




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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13881정성태2/7/2025393닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/2025439오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/2025501오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/2025695오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20251023닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
13876정성태1/25/20251168닷넷: 2314. C# - ProcessStartInfo 타입의 Arguments와 ArgumentList파일 다운로드1
13875정성태1/24/20251160스크립트: 69. 파이썬 - multiprocessing 패키지의 spawn 모드로 동작하는 uvicorn의 workers
13874정성태1/24/20251132스크립트: 68. 파이썬 - multiprocessing Pool의 기본 프로세스 시작 모드(spawn, fork)
13873정성태1/23/20251058디버깅 기술: 217. WinDbg - PCI 장치 열거
13872정성태1/23/20251045오류 유형: 944. WinDbg - 원격 커널 디버깅이 연결은 되지만 Break (Ctrl + Break) 키를 눌러도 멈추지 않는 현상
13871정성태1/22/20251159Windows: 278. Windows - 윈도우를 다른 모니터 화면으로 이동시키는 단축키 (Window + Shift + 화살표)
13870정성태1/18/20251235개발 환경 구성: 741. WinDbg - 네트워크 커널 디버깅이 가능한 NIC 카드 지원 확대
13869정성태1/18/20251256개발 환경 구성: 740. WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우
13868정성태1/17/20251195Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
13867정성태1/17/20251302오류 유형: 943. Hyper-V에 Windows 11 설치 시 "This PC doesn't currently meet Windows 11 system requirements" 오류
13866정성태1/16/20251308개발 환경 구성: 739. Windows 10부터 바뀐 device driver 서명 방법
13865정성태1/15/20251394오류 유형: 942. C# - .NET Framework 4.5.2 이하의 버전에서 HttpWebRequest로 https 호출 시 "System.Net.WebException" 예외 발생
13864정성태1/15/20251345Linux: 114. eBPF를 위해 필요한 SELinux 보안 정책
13863정성태1/14/20251285Linux: 113. Linux - 프로세스를 위한 전용 SELinux 보안 문맥 지정
13862정성태1/13/20251228Linux: 112. Linux - 데몬을 위한 SELinux 보안 정책 설정
13861정성태1/11/20251346Windows: 276. 명령행에서 원격 서비스를 동기/비동기로 시작/중지
13860정성태1/10/20251269디버깅 기술: 216. WinDbg - 2가지 유형의 식 평가 방법(MASM, C++)
13859정성태1/9/20251336디버깅 기술: 215. Windbg - syscall 이후 실행되는 KiSystemCall64 함수 및 SSDT 디버깅
13858정성태1/8/20251409개발 환경 구성: 738. PowerShell - 원격 호출 시 "powershell.exe"가 아닌 "pwsh.exe" 환경으로 명령어를 실행하는 방법
13857정성태1/7/20251820C/C++: 187. Golang - 콘솔 응용 프로그램을 Linux 데몬 서비스를 지원하도록 변경파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...