Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 3.2. VS.NET 2005 원격 디버깅 설정 [링크 복사], [링크+제목 복사],
조회: 22738
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기
(연관된 글이 2개 있습니다.)
VS.NET 2005 - 원격 디버깅


VS.NET 2005에서는 VS.NET 2003과는 달리 원격 디버깅 방식이 Managed와 Unmanaged로 나뉘지 않고 단일하게 MSVSMON.exe를 통해서 지원이 됩니다. 이름도 비슷하군요. VS.NET 2003에서는 msvcmon.exe라고 했지요. 이름으로 보자면, MDM.exe (Machine Debug Manager)가 진 것 같습니다. 어쨌든, 단일화 되었다는 것은 반가운 소식입니다. ^^ 더군다나, 64bit 환경- Itanium / x64 -에 대한 지원과 함께 32bit 머신에서 64bit 머신으로의 원격 디버깅까지 가능하도록 해줍니다.
그럼.. 하나씩 설명해 보도록 할까요! ^^

처음 시작할 것은, VS.NET 2003과 마찬가지로, 원격 PC에 원격 디버깅이 가능하도록 관련 파일을 미리 설치해 두는 것입니다.

- 원격 디버그 대상이 될 PC에 "MSVSMON.exe" 설치.

방법은 2가지가 있습니다. 설치 파일을 통한 방법과 단순히 XCopy 설치 방법이 있습니다.

1. 설치 파일을 통한 원격 디버깅 모듈 배포.
VS.NET 2005 CD 또는 공유 폴더에서 다음의 경로를 들어갑니다.
     [drive]:\[VS.NET 2005 설치 폴더]\Remote Debugger
예를 들어, "D:\vs\Remote Debugger" 정도가 되겠습니다. 들어가 보면 3가지 환경에 대한 디버그 설치 파일이 있습니다.
당연히 원격 PC 환경에 맞는 폴더로 들어가서 rdbgsetup.exe 파일을 실행시켜 주시면 됩니다.
예를 들어, 대상 PC가 "Windows Server 2003 for x64" 운영체제를 설치한 PC인 경우,
     D:\vs\Remote Debugger\x64\rdbgsetup.exe
를 실행시켜 주시면 됩니다.

2. XCopy 설치 방법.
개인적으로 즐겨쓰는 방법입니다. 위의 방법으로(rdbgsetup.exe) 설치한 폴더 또는 VS.NET 2005가 설치된 폴더로 이동합니다. 그럼 다음과 같은 폴더가 보입니다. 예를 들어, 제 PC에는 VS.NET 2005가 설치되어져 있어서 다음과 같은 경로에 Remote Debugger 관련 모듈이 있습니다.
     D:\Program Files\Microsoft Visual Studio 8\Common7\IDE\Remote Debugger
해당 폴더의 하위에는 x64, ia64, x86 폴더가 있으며 위의 rdbgsetup.exe 파일이 설치되었을 때의 파일들을 모두 포함하고 있습니다. msvsmon.exe는 별도의 레지스트리 설정을 하지 않고도 동작하기 때문에 그 폴더를 통째로 대상 PC에 복사해도 무방합니다. 예를 들어, 대상 PC가 "Windows XP(x86)" 운영체제를 설치한 PC인 경우,
"D:\Program Files\Microsoft Visual Studio 8\Common7\IDE\Remote Debugger\x86" 
폴더의 모든 내용을 원격 PC의 아무 폴더에나 그대로 xcopy를 해줍니다.

자, 이제 그럼 원격 디버깅을 위한 모듈 배포는 해결이 되었습니다. 그럼, 실제 원격 디버깅을 한번 살펴볼까요!


- ASP.NET 원격 디버깅

1. 원격 PC에 디버그하려는 웹 사이트에 대한 소스를 모두 복사합니다. 물론, dll과 pdb 파일 및 aspx 파일만 복사해도 무방합니다. 만약, 실서버에 대한 디버그를 하는 경우라면 이미 복사된 상태이겠지요.

2. 복사된 소스에 대해 원격 PC의 IIS 관리자에서 동일하게 웹 사이트 구성을 합니다. 가능한, 개발자 PC에서와 동일한 가상 디렉터리 구조로 유지하시는 것이 좋겠지요.

3. 원격 PC에서 msvsmon.exe 실행 파일이 있는 폴더에서 다음과 같은 명령어로 "명령창"에서 실행시켜 줍니다.

c:\msvsmon.exe
( 2006.08.11 변경 : Managed에 대한 원격 디버깅시에는 /noauth /anyuser 옵션을 주어서는 안됩니다. )

그럼, 다음과 같은 윈도우가 실행되어진 체로 유지가 됩니다.

msvsmon.exe 실행화면

4. 아쉽게도 VS.NET 2005에서도 웹 사이트에 대해서는 "F5 디버깅" 방식을 지원하지 않습니다. 따라서, "VS.NET 2003"에서 설명했던 데로, "Attach to Process" 방식으로 디버깅을 시작해야 합니다. "Debug" 메뉴 / "Attach to Process..." 메뉴를 선택하면 다음과 같은 화면이 나옵니다.
( 2006.08.11 변경 : ASP.NET에서 "F5 디버깅"이 지원됩니다. /2/0/315을 참조하십시오. )

ASP.NET 원격 디버그 설정
 Transport : Default
 Qualifier : [대상 컴퓨터 명 또는 IP]
 Attach to : Managed code
5. 이제 "Attach" 버튼을 누르면, w3wp.exe에 디버거가 붙게 되고, 웹 사이트를 IE로 방문하게 되면, VS.NET 2005에서 중단점을 설정한 곳에서 정상적으로 멈추게 됩니다.


- WinForm 원격 디버깅

1. "Attach to Process" 방식은 ASP.NET 사이트와 유사하게 진행이 됩니다. VS.NET 2003에서와 마찬가지로 WinForm 응용 프로그램인 경우, "F5 디버깅" 방식이 가능한데 아래 화면과 같이 "프로젝트 속성" 창을 통해서 가능합니다. 꽤나 간단해졌습니다. "Use remote machine"에 체크하고, 원격 컴퓨터 명과 함께 "Command line arguments"에 실행 파일 경로를 지정해 주면 됩니다.

WinForm 원격 디버그 설정


- VC++ App 원격 디버깅

1. 역시 기본적으로 "Attach to Process" 방식은 ASP.NET에서와 같습니다. WinForm 응용 프로그램과 같이 "F5 디버깅"을 지원하며 다음과 같은 "프로젝트 속성"을 통해서 가능합니다. 한 가지 더욱 편리한 것이 있는데요. 아래에서 "Debugger to launch" 아래에서 보는 것과 같이 간단하게 해당 항목을 선택하는 것만으로 디버그 환경을 "Local Windows Debugger", "Remote Windows Debugger" 등을 간편하게 전환할 수 있습니다.

MFC 원격 디버그 설정

한 가지, 더 특이한 것이 눈에 띄지요. 플랫폼 설정이 "x64"라고 되어 있는 것을 볼 수 있습니다. 이처럼, VS.NET 2005에서는 x64에 대한 디버거도 가능합니다. 이때, VS.NET 2005가 설치된 PC는 x86 machine이어도 상관이 없습니다. msvsmon.exe가 설치된 원격 PC만 x64 machine인 경우에도 x64 디버깅 환경을 지원합니다. 실제로, Registers 창이나, Disassembly 창을 보게 되면, 다음 화면과 같이 x64 관련 어셈블리 코드와 64bit 레지스터들을 확인할 수 있습니다.

MFC x64 원격 디버그 화면



지금까지 살펴본 것처럼, VS.NET 2005는 그야말로 최고의 디버거 환경을 제공해 주고 있습니다. 이외에도 Symbol Server로부터 PDB 파일들을 가져와서 구성하는 것이 가능하며, "Windows Compute Cluster Server 2003 (CCS)"에서 실행되는 다중 프로세스에 대한 디버깅 환경도 제공하고 있습니다. 그것이 바로 아래의 "MPI Cluster Debugger" 환경 구성입니다.

MPI 디버그 설정화면

MPI (Message Passing Interface)를 응용한 Cluster Solution을 구축하는 것에 관심이 있으시다면 다음의 URL을 참고하십시오.

Built For Speed - Develop Turbocharged Apps For Windows Compute Cluster Server
; https://docs.microsoft.com/en-us/archive/msdn-magazine/2006/april/develop-turbocharged-apps-for-windows-compute-cluster-server

마지막으로... Microsoft 의 노력에 박수를 보냅니다. ^^
[연관 글]






[최초 등록일: ]
[최종 수정일: 8/20/2021]

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

비밀번호

댓글 작성자
 




... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13147정성태10/25/20224973오류 유형: 823. Visual Studio 2022 - Unable to attach to CoreCLR. The debugger's protocol is incompatible with the debuggee.
13146정성태10/24/20225839.NET Framework: 2060. C# - Java의 Xmx와 유사한 힙 메모리 최댓값 제어 옵션 HeapHardLimit
13145정성태10/21/20226121오류 유형: 822. db2 - Password validation for user db2inst1 failed with rc = -2146500508
13144정성태10/20/20226012.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법파일 다운로드1
13143정성태10/19/20226542오류 유형: 821. windbg/sos - Error code - 0x000021BE
13142정성태10/18/20225804도서: 시작하세요! C# 12 프로그래밍
13141정성태10/17/20227128.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13140정성태10/11/20226444C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/20226181.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/20227553.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/20225872.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/20226440.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/20226714.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기
13134정성태10/4/20225403오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
13133정성태10/4/20225752Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]
13132정성태10/3/20225677스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현
13131정성태10/3/20228455.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/20225350.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/20225667.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
13128정성태9/23/20228345C/C++: 158. Visual C++ - IDL 구문 중 "unsigned long"을 인식하지 못하는 #import파일 다운로드1
13127정성태9/22/20226829Windows: 210. WSL에 systemd 도입
13126정성태9/15/20227423.NET Framework: 2049. C# 11 - 정적 메서드에 대한 delegate 처리 시 cache 적용
13125정성태9/14/20227650.NET Framework: 2048. C# 11 - 구조체 필드의 자동 초기화(auto-default structs)
13124정성태9/13/20227454.NET Framework: 2047. Golang, Python, C#에서의 CRC32 사용
13123정성태9/8/20227817.NET Framework: 2046. C# 11 - 멤버(속성/필드)에 지정할 수 있는 required 예약어 추가
13122정성태8/26/20227759.NET Framework: 2045. C# 11 - 메서드 매개 변수에 대한 nameof 지원
... 16  17  18  19  [20]  21  22  23  24  25  26  27  28  29  30  ...