Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [링크 복사], [링크+제목 복사]
조회: 22983
글쓴 사람
정성태 (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)
13484정성태12/14/20232175개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
13483정성태12/14/20232317닷넷: 2184. C# - 하나의 resource 파일을 여러 프로그램에서 (AOT 시에도) 사용하는 방법파일 다운로드1
13482정성태12/13/20232914닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법 [2]파일 다운로드1
13481정성태12/13/20232287개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법파일 다운로드1
13480정성태12/12/20232663개발 환경 구성: 692. Windows WSL 2 + Chrome 웹 브라우저 설치
13479정성태12/11/20232346개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정
13477정성태12/8/20232538닷넷: 2182. C# - .NET 7부터 추가된 Int128, UInt128 [1]파일 다운로드1
13476정성태12/8/20232273닷넷: 2181. C# - .NET 8 JsonStringEnumConverter의 AOT를 위한 개선파일 다운로드1
13475정성태12/7/20232340닷넷: 2180. .NET 8 - 함수 포인터에 대한 Reflection 정보 조회파일 다운로드1
13474정성태12/6/20232183개발 환경 구성: 690. 닷넷 코어/5+ 버전의 ilasm/ildasm 실행 파일 구하는 방법 - 두 번째 이야기
13473정성태12/5/20232394닷넷: 2179. C# - 값 형식(Blittable)을 메모리 복사를 이용해 바이트 배열로 직렬화/역직렬화파일 다운로드1
13472정성태12/4/20232216C/C++: 164. Visual C++ - InterlockedCompareExchange128 사용 방법
13471정성태12/4/20232294Copilot - To enable GitHub Copilot, authorize this extension using GitHub's device flow
13470정성태12/2/20232595닷넷: 2178. C# - .NET 8부터 COM Interop에 대한 자동 소스 코드 생성 도입파일 다운로드1
13469정성태12/1/20232317닷넷: 2177. C# - (Interop DLL 없이) CoClass를 이용한 COM 개체 생성 방법파일 다운로드1
13468정성태12/1/20232256닷넷: 2176. C# - .NET Core/5+부터 달라진 RCW(Runtime Callable Wrapper) 대응 방식파일 다운로드1
13467정성태11/30/20232353오류 유형: 882. C# - Unhandled exception. System.Runtime.InteropServices.COMException (0x800080A5)파일 다운로드1
13466정성태11/29/20232521닷넷: 2175. C# - DllImport 메서드의 AOT 지원을 위한 LibraryImport 옵션
13465정성태11/28/20232291개발 환경 구성: 689. MSBuild - CopyToOutputDirectory가 "dotnet publish" 시에는 적용되지 않는 문제파일 다운로드1
13464정성태11/28/20232419닷넷: 2174. C# - .NET 7부터 UnmanagedCallersOnly 함수 export 기능을 AOT 빌드에 통합파일 다운로드1
13463정성태11/27/20232377오류 유형: 881. Visual Studio - NU1605: Warning As Error: Detected package downgrade
13462정성태11/27/20232392오류 유형: 880. Visual Studio - error CS0246: The type or namespace name '...' could not be found
13461정성태11/26/20232413닷넷: 2173. .NET Core 3/5+ 기반의 COM Server를 registry 등록 없이 사용하는 방법파일 다운로드1
13460정성태11/26/20232365닷넷: 2172. .NET 6+ 기반의 COM Server 내에 Type Library를 내장하는 방법파일 다운로드1
13459정성태11/26/20232333닷넷: 2171. .NET Core 3/5+ 기반의 COM Server를 기존의 regasm처럼 등록하는 방법파일 다운로드1
13458정성태11/26/20232358닷넷: 2170. .NET Core/5+ 기반의 COM Server를 tlb 파일을 생성하는 방법(tlbexp)
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...