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
)
정성태

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13641정성태6/11/20248659Linux: 71. Ubuntu 20.04를 22.04로 업데이트
13640정성태6/10/20248821Phone: 21. C# MAUI - Android 환경에서의 파일 다운로드(DownloadManager)
13639정성태6/8/20248429오류 유형: 906. C# MAUI - Android Emulator에서 "Waiting For Debugger"로 무한 대기
13638정성태6/8/20248514오류 유형: 905. C# MAUI - 추가한 layout XML 파일이 Resource.Layout 멤버로 나오지 않는 문제
13637정성태6/6/20248446Phone: 20. C# MAUI - 유튜브 동영상을 MediaElement로 재생하는 방법
13636정성태5/30/20248078닷넷: 2264. C# - 형식 인자로 인터페이스를 갖는 제네릭 타입으로의 형변환파일 다운로드1
13635정성태5/29/20248936Phone: 19. C# MAUI - 안드로이드 "Share" 대상으로 등록하는 방법
13634정성태5/24/20249416Phone: 18. C# MAUI - 안드로이드 플랫폼에서의 Activity 제어 [1]
13633정성태5/22/20248935스크립트: 64. 파이썬 - ASGI를 만족하는 최소한의 구현 코드
13632정성태5/20/20248559Phone: 17. C# MAUI - Android 내에 Web 서비스 호스팅
13631정성태5/19/20249315Phone: 16. C# MAUI - /Download 등의 공용 디렉터리에 접근하는 방법 [1]
13630정성태5/19/20248863닷넷: 2263. C# - Thread가 Task보다 더 빠르다는 어떤 예제(?)
13629정성태5/18/20249151개발 환경 구성: 710. Android - adb.exe를 이용한 파일 전송
13628정성태5/17/20248540개발 환경 구성: 709. Windows - WHPX(Windows Hypervisor Platform)를 이용한 Android Emulator 가속
13627정성태5/17/20248603오류 유형: 904. 파이썬 - UnicodeEncodeError: 'ascii' codec can't encode character '...' in position ...: ordinal not in range(128)
13626정성태5/15/20248859Phone: 15. C# MAUI - MediaElement Source 경로 지정 방법파일 다운로드1
13625정성태5/14/20248917닷넷: 2262. C# - Exception Filter 조건(when)을 갖는 catch 절의 IL 구조
13624정성태5/12/20248712Phone: 14. C# - MAUI에서 MediaElement 사용파일 다운로드1
13623정성태5/11/20248418닷넷: 2261. C# - 구글 OAuth의 JWT (JSON Web Tokens) 해석파일 다운로드1
13622정성태5/10/20249205닷넷: 2260. C# - Google 로그인 연동 (ASP.NET 예제)파일 다운로드1
13621정성태5/10/20248636오류 유형: 903. IISExpress - Failed to register URL "..." for site "..." application "/". Error description: Cannot create a file when that file already exists. (0x800700b7)
13620정성태5/9/20248542VS.NET IDE: 190. Visual Studio가 node.exe를 경유해 Edge.exe를 띄우는 경우
13619정성태5/7/20248860닷넷: 2259. C# - decimal 저장소의 비트 구조파일 다운로드1
13618정성태5/6/20248653닷넷: 2258. C# - double (배정도 실수) 저장소의 비트 구조파일 다운로드1
13617정성태5/5/20249471닷넷: 2257. C# - float (단정도 실수) 저장소의 비트 구조파일 다운로드1
13616정성태5/3/20248617닷넷: 2256. ASP.NET Core 웹 사이트의 HTTP/HTTPS + Dual mode Socket (IPv4/IPv6) 지원 방법파일 다운로드1
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...