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

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13331정성태4/27/20233887오류 유형: 856. dockerfile - 구 버전의 .NET Core 이미지 사용 시 apt update 오류
13330정성태4/26/20233529Windows: 247. Win32 C/C++ - CS_GLOBALCLASS 설명
13329정성태4/24/20233733Windows: 246. Win32 C/C++ - 직접 띄운 대화창 템플릿을 위한 Modal 메시지 루프 생성파일 다운로드1
13328정성태4/19/20233403VS.NET IDE: 184. Visual Studio - Fine Code Coverage에서 동작하지 않는 Fake/Shim 테스트
13327정성태4/19/20233809VS.NET IDE: 183. C# - .NET Core/5+ 환경에서 Fakes를 이용한 단위 테스트 방법
13326정성태4/18/20235234.NET Framework: 2109. C# - 닷넷 응용 프로그램에서 SQLite 사용 (System.Data.SQLite) [1]파일 다운로드1
13325정성태4/18/20234527스크립트: 48. 파이썬 - PostgreSQL의 with 문을 사용한 경우 연결 개체 누수
13324정성태4/17/20234360.NET Framework: 2108. C# - Octave의 "save -binary ..."로 생성한 바이너리 파일 분석파일 다운로드1
13323정성태4/16/20234288개발 환경 구성: 677. Octave에서 Excel read/write를 위한 io 패키지 설치
13322정성태4/15/20235065VS.NET IDE: 182. Visual Studio - 32비트로만 빌드된 ActiveX와 작업해야 한다면?
13321정성태4/14/20233892개발 환경 구성: 676. WSL/Linux Octave - Python 스크립트 연동
13320정성태4/13/20233871개발 환경 구성: 675. Windows Octave 8.1.0 - Python 스크립트 연동
13319정성태4/12/20234318개발 환경 구성: 674. WSL 2 환경에서 GNU Octave 설치
13318정성태4/11/20234152개발 환경 구성: 673. JetBrains IDE에서 "Squash Commits..." 메뉴가 비활성화된 경우
13317정성태4/11/20234239오류 유형: 855. WSL 2 Ubuntu 20.04 - error: cannot communicate with server: Post http://localhost/v2/snaps/...
13316정성태4/10/20233566오류 유형: 854. docker-compose 시 "json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)" 오류 발생
13315정성태4/10/20233776Windows: 245. Win32 - 시간 만료를 갖는 컨텍스트 메뉴와 윈도우 메시지의 영역별 정의파일 다운로드1
13314정성태4/9/20233860개발 환경 구성: 672. DosBox를 이용한 Turbo C, Windows 3.1 설치
13313정성태4/9/20233938개발 환경 구성: 671. Hyper-V VM에 Turbo C 2.0 설치 [2]
13312정성태4/8/20233952Windows: 244. Win32 - 시간 만료를 갖는 MessageBox 대화창 구현 (개선된 버전)파일 다운로드1
13311정성태4/7/20234464C/C++: 163. Visual Studio 2022 - DirectShow 예제 컴파일(WAV Dest)
13310정성태4/6/20234064C/C++: 162. Visual Studio - /NODEFAULTLIB 옵션 설정 후 수동으로 추가해야 할 library
13309정성태4/5/20234231.NET Framework: 2107. .NET 6+ FileStream의 구조 변화
13308정성태4/4/20234124스크립트: 47. 파이썬의 time.time() 실숫값을 GoLang / C#에서 사용하는 방법
13307정성태4/4/20233888.NET Framework: 2106. C# - .NET Core/5+ 환경의 Windows Forms 응용 프로그램에서 HINSTANCE 구하는 방법
13306정성태4/3/20233681Windows: 243. Win32 - 윈도우(cbWndExtra) 및 윈도우 클래스(cbClsExtra) 저장소 사용 방법
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...