Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [링크 복사], [링크+제목 복사],
조회: 30358
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

새로운 Visual Studio 2012 원격 디버깅 툴


"Visual Studio Remote Debugger"라고 불리던 툴들이 2012로 오면서 "Remote Tools"라는 이름으로 변경되었습니다. Visual Studio 2012가 RTM 되면서 "Remote Tools"도 함께 다음의 링크에서 배포되고 있는데요.

Remote Tools for Visual Studio 2012
; http://www.microsoft.com/en-us/download/details.aspx?id=30674

2012 원격 디버깅 툴에서 변경된 점이 있다면, 가장 아쉬운 "Windows 서버 2003 미지원"에 대한 사항이 있습니다. 명세상으로는 심지어 Vista까지도 지원을 하지 않습니다. 따라서, 이런 운영체제에 실행되고 있는 응용 프로그램을 디버깅하려면 Visual Studio 2010으로 연결해야만 합니다. (문제군요. 그렇다면 .NET 4.5 응용 프로그램에 대해서는 Windows Server 2003에서 실행하는 경우 원격 디버깅을 할 수 없다는 이야기가 됩니다.)

계속해서, 원격 디버깅 관련하여 "방화벽" 설정을 살펴보겠습니다. (사실, Visual Studio 2010에서와 동일하지만 정리하는 차원에서 적어봅니다.)

우선, 방화벽으로 인해 원격 디버깅이 안 되는 경우 다음과 같은 오류 화면을 볼 수 있습니다.

rdbg_port_firewall_1.png

Unable to connect to the Microsoft Visual Studio Remote Debugging Monitor named '...'. This operation returned because the timeout period expired.


이런 경우, 몇몇 개의 외부 블로그를 참조하는 것이 도움이 되는데요.

Configuring XP SP2 to enable remote debugging for VS 2002/2003
; http://blogs.msdn.com/b/greggm/archive/2004/08/30/222935.aspx

Description of the DebuggerFirewall utility that makes the Visual Studio Remote Debugger work through the Windows XP Service Pack 2 firewall
; http://support.microsoft.com/?kbid=841177

How to turn on remote debugging in Windows XP with Service Pack 2, in Windows Server 2003 Service Pack 1, or in Windows Vista
; http://support.microsoft.com/kb/833977

"원격 디버깅"은 특이하게 해당 컴퓨터로의 연결뿐만 아니라, 그 컴퓨터에서 디버거가 위치한 컴퓨터로의 연결도 가능해야 합니다. 일단 대상 컴퓨터는 방화벽을 완전하게 풀어놓았다고 가정하고, Visual Studio가 위치한 측의 방화벽에 대해서만 살펴보겠습니다. (원격 컴퓨터 측의 설정은 http://support.microsoft.com/kb/833977 글에 포함돼 있습니다.)




원격 디버깅을 위해 Visual Studio가 실행되는 컴퓨터에 기본적으로 다음과 같은 포트를 열어주어야 합니다.

TCP 135
UDP 4500
UDP 500

"File and Print Sharing" 켜기
    File and Printer Sharing (NB-Session-In) (TCP 139)
    File and Printer Sharing (SMB-In) (TCP 445)
    File and Printer Sharing (NB-Name-In) (UDP 137)
    File and Printer Sharing (NB-Datagram-In) (UDP 138)

TCP 135, UDP 4500, UDP 500은 그냥 수작업으로 등록해 주어야 하지만, 나머지 "File and Print Sharing"과 관련해서는 Firewall 설정 프로그램에 다음과 같이 미리 입력되어 있기 때문에 이것들만 골라서 "Yes"로 돌려주면 됩니다.

rdbg_port_firewall_2.png

또한, 응용 프로그램을 등록해 주어야 하는데, "제어판" / "Windows Firewall" 패널에서 좌측의 "Allow an app or feature through Windows Firewall" 링크를 눌러서, Visual Studio 2012 프로그램을 추가합니다. (참고로 설치된 경로가 맞는지 - 예를 들어, "C:\Program Files (x86)\Microsoft Visual Studio 11.0\Common7\IDE\devenv.exe" - 반드시 확인합니다.)

보통의 경우, 위와 같이만 해주면 잘 동작할 텐데요. 특정한 상황에서 여전히 다음과 같은 오류가 발생할 수 있습니다.

Unable to connect to the Microsoft Visual Studio Remote Debugging Monitor named '...'. The Visual Studio Remote Debugger on the target computer cannot connect back to this computer. A firewall may be preventing communication via DCOM to the local computer. Please see Help for assistance.


확인을 위해 대상 컴퓨터에서 ping으로 Visual Studio가 설치된 PC로 통신이 되는지 확인을 합니다. (Ping을 위한 ICMP 테스트를 위해 방화벽에서 "File and Printer Sharing (Echo Request - ICMPv4-In)" 항목을 활성화해야 합니다.)

이때, IP로 한 번 해보고 컴퓨터 명으로도 한 번 해봅니다. 만약 IP로는 되는데 컴퓨터 명으로는 안 된다면 수작업으로 HOSTS 파일에 등록을 해주면 원격 디버깅이 정상적으로 동작할 수 있게 됩니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/11/2023]

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

비밀번호

댓글 작성자
 



2012-11-28 02시31분
Remote Tools for Visual Studio 2012 Update 1
; http://www.microsoft.com/en-us/download/details.aspx?id=30674
정성태
2018-11-21 02시33분
[초보개발] 위에는 글을 어떻게 쓰는지 잘못 올렸습니다 ㅠㅠ
다름이 아니라..

제가 소스 파일을 하나 받았습니다.
이게 windows 서버 2012 r2에서 돌아가기때문에 window 10에 있는 소스를 원격 리모트 ?? 프로세스 디버깅 해야합니다..

그래서 궁금한게.. 서버 2012 r2에 원격도구를 설치를하고 소스있는 win10에서 원격지로 프로세스를 해줘야하나요 ??
[guest]
2018-11-21 08시48분
물론, 여러가지 방법이 있지만 간단하게는 다음과 같이 해주는 것이 가장 편합니다.

우선, 자신의 컴퓨터에서 제공받은 소스 코드를 빌드합니다. 그 빌드 결과물을 Windows Server 2012 R2에 복사해 실행하고, 그 서버에는 원격 디버깅 도구를 설치해 놓은 상태여야 합니다. 그다음, 자신의 컴퓨터에 있는 비주얼 스튜디오를 이용해 "Attach to Process" 기능으로 원격지 컴퓨터에 연결해 디버깅하면 됩니다.

보다 자세한 정보는 다음의 글을 참고하세요.

Remote Debugging
; https://learn.microsoft.com/en-us/visualstudio/debugger/remote-debugging
정성태
2018-11-23 10시13분
[초보개발] 감사합니다. 실행이 되네요.
원격 디버깅이라는게 exe 같은 프로세스를 지정해 두고 디버깅을 해야하는거같은데요..
이게 exe 안돌리도 한줄한줄 보면서 돌릴수 있나요 ?

윈도우 서버단에서 실행되는 ad 관련 소스라.. 꼭 윈도우 서버에서 돌려하는데..

디버깅하다보면 exe로실행 될때 그 단위만 들어가게되고 나머진 세세하게 볼 수는 없더라고요..
[guest]
2018-11-24 07시36분
원격 디버깅 자체가, 다른 PC에 EXE를 실행하고 디버깅하는 것입니다. 당연히 EXE 실행 없이 한줄씩 보면서 돌릴 수 없습니다.

그런데, EXE로 실행될 떄 그 단위만 들어가고 나머지는 세세하게 볼 수 없다는 것이 무슨 의미인가요? 원격 디버깅은 로컬 디버깅과 거의 같은 수준의 경험으로 디버깅할 수 있습니다.
정성태

... 76  77  78  79  80  81  82  83  [84]  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11836정성태3/5/201923184오류 유형: 525. Visual Studio 2019 Preview 4/RC - C# 8.0 Missing compiler required member 'System.Range..ctor' [1]
11835정성태3/5/201921708.NET Framework: 810. C# 8.0의 Index/Range 연산자를 .NET Framework에서 사용하는 방법 및 비동기 스트림의 컴파일 방법 [3]파일 다운로드1
11834정성태3/4/201920550개발 환경 구성: 432. Visual Studio 없이 최신 C# (8.0) 컴파일러를 사용하는 방법
11833정성태3/4/201921051개발 환경 구성: 431. Visual Studio 2019 - CMake를 이용한 공유/실행(so/out) 리눅스 프로젝트 설정파일 다운로드1
11832정성태3/4/201916990오류 유형: 524. Visual Studio CMake - rsync: connection unexpectedly closed
11831정성태3/4/201916805오류 유형: 523. Visual Studio 2019 - 새 창으로 뜬 윈도우를 닫을 때 비정상 종료
11830정성태2/26/201916497오류 유형: 522. 이벤트 로그 - Error opening event log file State. Log will not be processed. Return code from OpenEventLog is 87.
11829정성태2/26/201918252개발 환경 구성: 430. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 - 리눅스 환경 [1]
11828정성태2/26/201926126개발 환경 구성: 429. Component Services 관리자의 RuntimeBroker 설정이 2개 있는 경우 [8]
11827정성태2/26/201919049오류 유형: 521. Visual Studio - Could not start the 'rsync' command on the remote host, please install it using your system package manager.
11826정성태2/26/201919241오류 유형: 520. 우분투에 .NET Core SDK 설치 시 패키지 의존성 오류
11825정성태2/25/201924448개발 환경 구성: 428. Visual Studio 2019 - CMake를 이용한 리눅스 빌드 환경 설정 [1]
11824정성태2/25/201918890오류 유형: 519. The SNMP Service encountered an error while accessing the registry key SYSTEM\CurrentControlSet\Services\SNMP\Parameters\TrapConfiguration. [1]
11823정성태2/21/201920616오류 유형: 518. IIS 관리 콘솔이 뜨지 않는 문제
11822정성태2/20/201918908오류 유형: 517. docker에 설치한 MongoDB 서버로 연결이 안 되는 경우
11821정성태2/20/201919673오류 유형: 516. Visual Studio 2019 - This extension uses deprecated APIs and is at risk of not functioning in a future VS update. [1]
11820정성태2/20/201922737오류 유형: 515. 윈도우 10 1809 업데이트 후 "User Profiles Service" 1534 경고 발생
11819정성태2/20/201922023Windows: 158. 컴퓨터와 사용자의 SID(security identifier) 확인 방법
11818정성태2/20/201920062VS.NET IDE: 131. Visual Studio 2019 Preview의 닷넷 프로젝트 빌드가 20초 이상 걸리는 경우 [2]
11817정성태2/17/201916445오류 유형: 514. WinDbg Preview 실행 오류 - Error : DbgX.dll : WindowsDebugger.WindowsDebuggerException: Could not load dbgeng.dll
11816정성태2/17/201919848Windows: 157. 윈도우 스토어 앱(Microsoft Store App)을 명령행에서 직접 실행하는 방법
11815정성태2/14/201918095오류 유형: 513. Visual Studio 2019 - VSIX 설치 시 "The extension cannot be installed to this product due to prerequisites that cannot be resolved." 오류 발생
11814정성태2/12/201916962오류 유형: 512. VM(가상 머신)의 NT 서비스들이 자동 시작되지 않는 문제
11813정성태2/12/201918311.NET Framework: 809. C# - ("Save File Dialog" 등의) 대화 창에 확장 속성을 보이는 방법
11812정성태2/11/201915608오류 유형: 511. Windows Server 2003 VM 부팅 후 로그인 시점에 0xC0000005 BSOD 발생
11811정성태2/11/201920786오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제
... 76  77  78  79  80  81  82  83  [84]  85  86  87  88  89  90  ...