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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
13566정성태2/27/20249540오류 유형: 897. Windows 7 SDK 설치 시 ".NET Development" 옵션이 비활성으로 선택이 안 되는 경우
13565정성태2/23/20248636닷넷: 2219. .NET CLR2 보안 모델에서의 개별 System.Security.Permissions 제어
13564정성태2/22/202410152Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
13563정성태2/21/20249643디버깅 기술: 196. windbg - async/await 비동기인 경우 메모리 덤프 분석의 어려움
13562정성태2/21/20249340오류 유형: 896. ASP.NET - .NET Framework 기본 예제에서 System.Web에 대한 System.IO.FileNotFoundException 예외 발생
13561정성태2/20/202410140닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/202410190디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/202411007오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/202410177닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20249052Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20249428Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20249639닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20249068VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20248607닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20248727닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20249814닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/202410257Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/202411234개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/202410800개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/202410452개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/202410143Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20249681닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20249334오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20249763Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20248834오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20249595VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...