Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [링크 복사], [링크+제목 복사],
조회: 22997
글쓴 사람
정성태 (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로 실행될 떄 그 단위만 들어가고 나머지는 세세하게 볼 수 없다는 것이 무슨 의미인가요? 원격 디버깅은 로컬 디버깅과 거의 같은 수준의 경험으로 디버깅할 수 있습니다.
정성태

... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
12981정성태2/23/20226801VC++: 154. C/C++ 언어의 문자열 Literal에 인덱스 적용하는 구문 [1]
12980정성태2/23/20227546.NET Framework: 1163. C# - 윈도우 환경에서 usleep을 호출하는 방법 [2]
12979정성태2/22/202210122.NET Framework: 1162. C# - 인텔 CPU의 P-Core와 E-Core를 구분하는 방법 [1]파일 다운로드2
12978정성태2/21/20227454.NET Framework: 1161. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 resampling_audio.c 예제 포팅
12977정성태2/21/202211166.NET Framework: 1160. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsv 디코딩
12976정성태2/21/20226784VS.NET IDE: 174. Visual C++ - "External Dependencies" 노드 비활성화하는 방법
12975정성태2/20/20228535.NET Framework: 1159. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsvdec.c 예제 포팅파일 다운로드1
12974정성태2/20/20226667.NET Framework: 1158. C# - SqlConnection의 최소 Pooling 수를 초과한 DB 연결은 언제 해제될까요?
12973정성태2/16/20228960개발 환경 구성: 639. ffmpeg.exe - Intel Quick Sync Video(qsv)를 이용한 인코딩 [3]
12972정성태2/16/20228235Windows: 200. Intel CPU의 내장 그래픽 GPU가 작업 관리자에 없다면? [4]
12971정성태2/15/20229883.NET Framework: 1157. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 muxing.c 예제 포팅 [7]파일 다운로드2
12970정성태2/15/20228018.NET Framework: 1156. C# - ffmpeg(FFmpeg.AutoGen): Bitmap으로부터 h264 형식의 파일로 쓰기 [1]파일 다운로드1
12969정성태2/14/20226583개발 환경 구성: 638. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구 - 두 번째 이야기파일 다운로드1
12968정성태2/14/20226789오류 유형: 794. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for '...'.
12967정성태2/14/20227146VC++: 153. Visual C++ - C99 표준의 Compund Literals 빌드 방법 [4]
12966정성태2/13/20226992.NET Framework: 1155. C# - ffmpeg(FFmpeg.AutoGen): Bitmap으로부터 yuv420p + rawvideo 형식의 파일로 쓰기파일 다운로드1
12965정성태2/13/20226919.NET Framework: 1154. "Hanja Hangul Project v1.01 (파이썬)"의 C# 버전
12964정성태2/11/20227236.NET Framework: 1153. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 avio_reading.c 예제 포팅파일 다운로드1
12963정성태2/11/20227969.NET Framework: 1152. C# - 화면 캡처한 이미지를 ffmpeg(FFmpeg.AutoGen)로 동영상 처리 (저해상도 현상 해결)파일 다운로드1
12962정성태2/9/20227818오류 유형: 793. 마이크로소프트 스토어 - 제품이 존재하지 않습니다. 재고가 없는 것일 수 있습니다.
12961정성태2/8/20227955.NET Framework: 1151. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 프레임의 크기 및 포맷 변경 예제(scaling_video.c) [7]파일 다운로드1
12960정성태2/8/20227339개발 환경 구성: 637. ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 디코딩 예제(decode_video.c) - 세 번째 이야기
12959정성태2/7/20228051.NET Framework: 1150. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 디코딩 예제(decode_video.c) - 두 번째 이야기 [2]파일 다운로드1
12958정성태2/6/20228115.NET Framework: 1149. C# - ffmpeg(FFmpeg.AutoGen) - 비디오 프레임 디코딩 [2]파일 다운로드1
12957정성태2/6/20227727개발 환경 구성: 636. ffmpeg.exe를 이용해 planar 포맷의 데이터를 packed 형식으로 변환하는 방법? [2]
12956정성태2/4/20226966.NET Framework: 1148. C# - ffmpeg(FFmpeg.AutoGen) - decoding 과정 [2]파일 다운로드1
... 16  17  18  19  20  21  22  23  24  25  [26]  27  28  29  30  ...