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

비밀번호

댓글 작성자
 




... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
795정성태11/2/200925665오류 유형: 88. TFS 2010 (beat2) 설치 오류 -TF255272
793정성태10/19/200927643.NET Framework: 166. WPF - XAML 요소의 네임스페이스와 CLR 타입 매핑
792정성태10/17/200927880웹: 13. IIS 7.5 에서 SQL Express 연결 시 오류
791정성태10/17/200931677웹: 12. 요청 페이지에 대해 빈 화면만 보이는 경우 [1]
789정성태10/13/200927383COM 개체 관련: 22. BB FlashBack SDK와 ActiveX 버전 관리 [7]
786정성태10/9/200923622개발 환경 구성: 52. 테스트를 위한 평가판 운영체제 구하기
785정성태10/8/200930235.NET Framework: 165. WPF - UI 업데이트를 바로 반영하고 싶다면? (2)파일 다운로드1
783정성태10/7/200928002.NET Framework: 164. WPF - 데이터 바인딩된 트리에서 부모 노드 찾는 방법 [1]파일 다운로드1
782정성태10/6/200929865개발 환경 구성: 51. Windows 7 - 다중 원격 접속(Remote Desktop) 허용
781정성태9/30/200926882.NET Framework: 163. WPF - TreeView 자동 스크롤 기능 해지 [2]파일 다운로드1
780정성태9/28/200930978Windows: 48. Windows 7/2008에서 ping을 위한 echo 요청 열기 [2]
779정성태9/24/200922316.NET Framework: 162. WPF - 중첩된 ScrollViewer의 크기 제어 - 두 번째 이야기파일 다운로드1
778정성태9/23/200923765오류 유형: 87. 시스템 시간 변경 후 Session이 맺어진 WCF 클라이언트의 예외 발생파일 다운로드1
776정성태9/17/200923002개발 환경 구성: 50. Reference assembly
775정성태9/13/200939717VC++: 37. XmlCodeGenerator를 C/C++ 코드 생성에 적용 [2]파일 다운로드1
773정성태9/5/200930234오류 유형 : 85. DEP 비호환 ActiveX 오류
772정성태9/2/200926806.NET Framework: 161. WPF - 윈도우 이벤트 가로채기 [1]파일 다운로드1
771정성태8/28/200920850.NET Framework: 160. WPF - 입력 포커스 외곽선 없애는 방법
770정성태8/26/200923154.NET Framework: 159. WCF - 같은 컴퓨터에서만 WCF 요청을 서비스하도록 설정
769정성태8/25/200926198개발 환경 구성: 49. GAC와 같은 Namespace Extension에 의해서 보여지는 폴더의 원본 확인 방법
768정성태8/24/200925656오류 유형: 85. WCF 연결 오류: MessageSecurityException
767정성태8/23/200933907.NET Framework: 158. 닷넷 프로파일러 - IL 코드 재작성 [14]
766정성태8/23/200934779.NET Framework: 157. C# 4.0 - dynamic 키워드 [4]파일 다운로드1
765정성태8/22/200928557.NET Framework: 156. XamDataGrid의 UnboundField 사용파일 다운로드1
764정성태8/21/200922880Windows: 47. Windows Virtual PC에 설치된 Windows 7 VPC에서 Aero 효과 사용 [3]
763정성태8/20/200926505Windows: 46. Windows 7 - XP 모드 응용 프로그램 바로가기 만드는 방법 [2]
... 166  167  168  [169]  170  171  172  173  174  175  176  177  178  179  180  ...