Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

원격 데스크톱 접속(RDP)을 기존의 콘솔 모드처럼 사용하는 방법

그동안 RDP 접속에서 한 가지 아쉬운 것이 있었으니, 바로 RDP(mstsc.exe)로 원격 컴퓨터에 콘솔(console) 모드로 접속하는 것입니다. 이유를 들기 위해 몇 가지 예를 볼까요?

Genymotion 같은 에뮬레이터를,

PC 용 무료 안드로이드 에뮬레이터 - genymotion
; https://www.sysnet.pe.kr/2/0/1716

RDP 접속 화면에서 실행해, 가상 장치를 띄우는 경우 다음과 같은 오류가 발생합니다.

rdp_console_mode_1.png

Warning: CPU number has been forced to 1.

Virtualization technologies not available in your CPU.

You wont be able to use the multi-processors support.

See the FAQ for more information about the virtualization technologies:
https://cloud.genymotion.com/page/faq/#collapse-perfs

Unable to start the Genymotion virtual device.

Check if your video card supports OpenGL. If no, then Genymotion virtual device can not start. If yes, maybe you should update your video card drivers.

Detailed information: Failed to initialize backend EGL display (error: 4)

If needed, update your video card drivers.

OpenGL을 지원하는 비디오 카드가 없다고 하는 것입니다. 실제로 RDP로 접속하는 경우 dxdiag.exe를 실행하면 다음과 같이 "Direct3D Acceleration" 항목만 "Enabled"로 표시됩니다.

rdp_console_mode_2.png

한마디로, RDP 환경에서는 완벽한 GPU 지원을 받을 수 없는 것입니다. 이와 관련해서 문제되는 것이 있다면 게임일 것입니다. (물론, RDP 접속 화면에서 게임을 하면 끊기는 현상이 심해 도저히 할 수 없을 정도이지만.) 이 외에도 최근에 테스트했던 비트코인 채굴 프로그램에서 유사한 문제가 발생했습니다. 아래는 델 베뉴 8 프로에서 GUIMiner를 실행했을 때 보여지는 장치 목록입니다.

rdp_console_mode_3.png

하지만 RDP 접속 화면에서 동일한 프로그램을 실행시켜 보면,

rdp_console_mode_4.png

보시는 것처럼 "Intel(R) Atom(TM) CPU Z37" 항목밖에는 잡히지 않습니다. 즉, GPU 연산장치가 안 잡히는 것입니다. 심지어 CPU 마저 지원 장치가 아니라면 다음과 같은 식의 오류 화면이 뜹니다.

No OpenCL devices were found.
If you only want to mine using CPU or CUDA, you can ignore this message.
If you want to mine on ATI graphics cards, you may need to install the ATI Stream SDK, or your GPU may not support OpenCL.

NVidia 그래픽 카드가 있는 컴퓨터에서도 cuda 용 마이너를 RDP 접속화면에서 실행하면,

c:\cuda>rpcminer-cuda.exe
Client will start 1 miner threads
Work will be refreshed every 4000 ms
Unable to initialize CUDA

이런 식으로 오류가 발생합니다. 이처럼, RDP 접속 화면의 제약은 주로 GPU 장치와 연관해서 심심치 않게 발생합니다.




그런데 재미있는 특징이 하나 있습니다. 해당 물리 PC에 직접 로그인 한 다음 RDP 화면에서는 제약이 있었던 그 게임들을 GPU 초기화 단계까지만 넘어가면 이후로는 정상적으로 동작한다는 점입니다.

예를 들어, 위에서 예를 들었던 guiminer.exe를 물리 PC에 직접 로그인한 상태에서 실행시키고 GPU를 선택해 실행시켜 두면, 이후로는 RDP 화면으로 접속해도 실행은 정상적으로 계속됩니다.

rdp_console_mode_5.png

마찬가지로 Genymotion의 가상 장치도 일단 물리 PC에 로그인해서 실행시켜 두면 RDP 접속을 해서 잘 사용할 수 있고, RDP 접속 시에는 실행에 실패하던 게임도 일단 물리 PC에서 실행만 해두면 이후에는 RDP 접속을 해도 실행 중이던 게임이 튕기거나 하지는 않습니다.




물론, 이런 식으로 실행하는 데에는 약간의 제약이 있습니다. 반드시 해당 컴퓨터에 가서 로그인을 한 다음 프로그램을 실행시키고 다시 RDP 접속을 해야하는 번거로움이 있습니다. 당연히 물리적으로 떨어져 있는 컴퓨터라면 이것이 여간 불편한 작업이 아닐 수 없습니다.

사실, 예전에는 콘솔 모드 접속이 있어서 이런 제약이 없었습니다. "mstsc.exe /console" 옵션이 그것이었는데 (제 기억으로는) VISTA 운영체제 이후로 /console 옵션을 없애고 대신 유사한 /admin 옵션으로 대체했습니다. 하지만, /admin 옵션은 콘솔 모드를 지원하는 것이 아니므로 위에서 설명한 것과 같은 불편함이 있습니다.

그런데, 최근에 이런 제약을 우회할 수 있는 한가지 묘안이 떠올랐습니다. ^^ 이를 위해서는 몇 가지 조합이 필요한데요. 그중 하나가 RDP shadow 기능입니다. 그래서 지난번에 이런 글을 쓴 것이지요. ^^

윈도우 8 - RDP 연결을 이용해 VNC처럼 사용자 로그온 화면을 공유하는 방법
; https://www.sysnet.pe.kr/2/0/1752

자... 그럼 어떻게 해결할 수 있는지 한번 직접 해볼까요? ^^

우선, "A 컴퓨터(IP: 192.168.100.5)"와 "B 컴퓨터를 마련합니다. "A 컴퓨터"가 바로 원격지 컴퓨터이고 "B 컴퓨터"는 RDP(mstsc.exe)로 "A 컴퓨터"에 접속할 것입니다.

당연히 2대의 컴퓨터를 모두 켜고, "B 컴퓨터"에서 기존과 다름없이 RDP 접속을 합니다.

c:\>mstsc /v:192.168.100.5

그런 후 tscon 프로그램을 실행시켜 현재 RDP 접속 화면을 콘솔로 연결합니다. 이를 위해 우선 현재 접속된 RDP의 세션 번호를 알아야 합니다.

C:\>query session
 SESSIONNAME       USERNAME                 ID  STATE   TYPE        DEVICE
 services                                    0  Disc
>rdp-tcp#36        TESTERA            1  Active
 console                                     3  Conn
 rdp-tcp                                 65536  Listen

보시면 RDP 세션의 이름은 "rdp-tcp#36"이고 ID 번호는 1번 임을 알 수 있습니다.

이제 cmd.exe를 관리자 권한으로 실행한 후 다음과 같이 tscon 프로그램을 실행시킵니다.

tscon 1 /dest:console

위의 프로그램이 정상적으로 실행되면 현재 RDP 접속이 해제되어 버립니다. 놀라지 마세요. ^^ 정상입니다. 이때, "A 컴퓨터"에 연결된 모니터를 보세요. 흥미롭게도 우리가 마지막으로 접속했던 RDP 화면이 떠 있을 것입니다. 즉, RDP 세션이 콘솔 세션으로 교체된 것입니다.

그런데, 여기까지만 하면 더 이상 원격지에서 제어를 할 수가 없어 쓸모가 없습니다. 바로 이때 shadow 접속을 하면 됩니다.

mstsc /v:192.168.100.5 /shadow:1 /control /noConsentPrompt

그럼, 콘솔 화면과 그대로 복제되어 RDP 접속이 됩니다. 따라서 이 상태에서 실행하는 프로그램은 콘솔 모드에서 실행하는 것과 동일하므로 현재의 RDP 화면에서 콘솔 모드로만 실행이 가능했던 프로그램을 실행시킵니다. 그럼 문제가 해결된 것이죠!!!

그런데 이렇게만 두면 원격지에 있는 컴퓨터가 로그인이 풀린 체로 화면에 떠 있게 되므로 보안상 좋지 않습니다. 콘솔 모드로만 실행이 가능한 프로그램만 실행한 다음 다시 RDP 접속을 해서 원격지 로그인 화면을 잠금 상태로 돌려두는 것이 좋습니다.

c:\>mstsc /v:192.168.100.5

뭐... 이 정도면, 아쉽지만 콘솔 모드 RDP 접속이 사라진 것에 대한 미봉책이 될 듯 싶습니다. ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 



2015-09-08 11시44분
https://support.smartbear.com/viewarticle/72794/

for /f "skip=1 tokens=3" %%s in ('query user %USERNAME%') do (
  %windir%\System32\tscon.exe %%s /dest:console
)
정성태

... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12621정성태5/1/202110480.NET Framework: 1053. C# - 특정 레지스트리 변경 시 알림을 받는 방법 [1]파일 다운로드1
12620정성태4/29/202112415.NET Framework: 1052. C# - 왜 구조체는 16 바이트의 크기가 적합한가? [1]파일 다운로드1
12619정성태4/28/202112930.NET Framework: 1051. C# - 구조체의 크기가 16바이트가 넘어가면 힙에 할당된다? [2]파일 다운로드1
12618정성태4/27/202111385사물인터넷: 58. NodeMCU v1 ESP8266 CP2102 Module을 이용한 WiFi UDP 통신 [1]파일 다운로드1
12617정성태4/26/20219205.NET Framework: 1050. C# - ETW EventListener의 Keywords별 EventId에 따른 필터링 방법파일 다운로드1
12616정성태4/26/20219054.NET Framework: 1049. C# - ETW EventListener를 상속받았을 때 초기화 순서파일 다운로드1
12615정성태4/26/20217088오류 유형: 712. Microsoft Live 로그인 - 계정을 선택하는(Pick an account) 화면에서 진행이 안 되는 문제
12614정성태4/24/20219930개발 환경 구성: 570. C# - Azure AD 인증을 지원하는 ASP.NET Core/5+ 웹 애플리케이션 예제 구성 [4]파일 다운로드1
12613정성태4/23/20218992.NET Framework: 1048. C# - ETW 이벤트의 Keywords에 속한 EventId 구하는 방법 (2) 관리 코드파일 다운로드1
12612정성태4/23/20219119.NET Framework: 1047. C# - ETW 이벤트의 Keywords에 속한 EventId 구하는 방법 (1) PInvoke파일 다운로드1
12611정성태4/22/20218377오류 유형: 711. 닷넷 EXE 실행 오류 - Mixed mode assembly is build against version 'v2.0.50727' of the runtime
12610정성태4/22/20218272.NET Framework: 1046. C# - 컴파일 시점에 참조할 수 없는 타입을 포함한 이벤트 핸들러를 Reflection을 이용해 구독하는 방법파일 다운로드1
12609정성태4/22/20219684.NET Framework: 1045. C# - 런타임 시점에 이벤트 핸들러를 만들어 Reflection을 이용해 구독하는 방법파일 다운로드1
12608정성태4/21/202110567.NET Framework: 1044. C# - Generic Host를 이용해 .NET 5로 리눅스 daemon 프로그램 만드는 방법 [9]파일 다운로드1
12607정성태4/21/20219073.NET Framework: 1043. C# - 실행 시점에 동적으로 Delegate 타입을 만드는 방법파일 다운로드1
12606정성태4/21/202113219.NET Framework: 1042. C# - enum 값을 int로 암시적(implicit) 형변환하는 방법? [2]파일 다운로드1
12605정성태4/18/20219130.NET Framework: 1041. C# - AssemblyID, ModuleID를 관리 코드에서 구하는 방법파일 다운로드1
12604정성태4/18/20217708VS.NET IDE: 163. 비주얼 스튜디오 속성 창의 "Build(빌드)" / "Configuration(구성)"에서의 "활성" 의미
12603정성태4/16/20218599VS.NET IDE: 162. 비주얼 스튜디오 - 상속받은 컨트롤이 디자인 창에서 지원되지 않는 문제
12602정성태4/16/20219807VS.NET IDE: 161. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 [1]
12601정성태4/15/20218871.NET Framework: 1040. C# - REST API 대신 github 클라이언트 라이브러리를 통해 프로그래밍으로 접근
12600정성태4/15/20219046.NET Framework: 1039. C# - Kubeconfig의 token 설정 및 인증서 구성을 자동화하는 프로그램
12599정성태4/14/20219790.NET Framework: 1038. C# - 인증서 및 키 파일로부터 pfx/p12 파일을 생성하는 방법파일 다운로드1
12598정성태4/14/20219906.NET Framework: 1037. openssl의 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 (2)파일 다운로드1
12597정성태4/13/20219968개발 환경 구성: 569. csproj의 내용을 공통 설정할 수 있는 Directory.Build.targets / Directory.Build.props 파일
12596정성태4/12/20219700개발 환경 구성: 568. Windows의 80 포트 점유를 해제하는 방법
... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...