Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [링크 복사], [링크+제목 복사]
조회: 22982
글쓴 사람
정성태 (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)
13535정성태1/22/20242430닷넷: 2208. C# - GCHandle 구조체의 메모리 분석
13534정성태1/21/20242249닷넷: 2207. C# - SQL Server DB를 bacpac으로 Export/Import파일 다운로드1
13533정성태1/18/20242462닷넷: 2206. C# - TCP KeepAlive의 서버 측 구현파일 다운로드1
13532정성태1/17/20242353닷넷: 2205. C# - SuperSimpleTcp 사용 시 주의할 점파일 다운로드1
13531정성태1/16/20242246닷넷: 2204. C# - TCP KeepAlive에 새로 추가된 Retry 옵션파일 다운로드1
13530정성태1/15/20242199닷넷: 2203. C# - Python과의 AES 암호화 연동파일 다운로드1
13529정성태1/15/20242058닷넷: 2202. C# - PublishAot의 glibc에 대한 정적 링킹하는 방법
13528정성태1/14/20242183Linux: 68. busybox 컨테이너에서 실행 가능한 C++, Go 프로그램 빌드
13527정성태1/14/20242127오류 유형: 892. Visual Studio - Failed to launch debug adapter. Additional information may be available in the output window.
13526정성태1/14/20242211닷넷: 2201. C# - Facebook 연동 / 사용자 탈퇴 처리 방법
13525정성태1/13/20242162오류 유형: 891. Visual Studio - Web Application을 실행하지 못하는 IISExpress
13524정성태1/12/20242225오류 유형: 890. 한국투자증권 KIS Developers OpenAPI - GW라우팅 중 오류가 발생했습니다.
13523정성태1/12/20242033오류 유형: 889. Visual Studio - error : A project with that name is already opened in the solution.
13522정성태1/11/20242198닷넷: 2200. C# - HttpClient.PostAsJsonAsync 호출 시 "Transfer-Encoding: chunked" 대신 "Content-Length" 헤더 처리
13521정성태1/11/20242263닷넷: 2199. C# - 한국투자증권 KIS Developers OpenAPI의 WebSocket Ping, Pong 처리
13520정성태1/10/20242005오류 유형: 888. C# - Unable to resolve service for type 'Microsoft.Extensions.ObjectPool.ObjectPool`....'
13519정성태1/10/20242096닷넷: 2198. C# - Reflection을 이용한 ClientWebSocket의 Ping 호출파일 다운로드1
13518정성태1/9/20242362닷넷: 2197. C# - ClientWebSocket의 Ping, Pong 처리
13517정성태1/8/20242202스크립트: 63. Python - 공개 패키지를 이용한 위성 이미지 생성 (pystac_client, odc.stac)
13516정성태1/7/20242314닷넷: 2196. IIS - AppPool의 "Disable Overlapped Recycle" 옵션의 부작용
13515정성태1/6/20242590닷넷: 2195. async 메서드 내에서 C# 7의 discard 구문 활용 사례 [1]
13514정성태1/5/20242263개발 환경 구성: 702. IIS - AppPool의 "Disable Overlapped Recycle" 옵션
13513정성태1/5/20242188닷넷: 2194. C# - WebActivatorEx / System.Web의 PreApplicationStartMethod 특성
13512정성태1/4/20242153개발 환경 구성: 701. IIS - w3wp.exe 프로세스의 ASP.NET 런타임을 항상 Warmup 모드로 유지하는 preload Enabled 설정
13511정성태1/4/20242175닷넷: 2193. C# - ASP.NET Web Application + OpenAPI(Swashbuckle) 스펙 제공
13510정성태1/3/20242106닷넷: 2192. C# - 특정 실행 파일이 있는지 확인하는 방법 (Linux)
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...