Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio로 디버깅 시 sos.dll 확장 명령어를 (비롯한 windbg의 다양한 기능을) 수행하는 방법

미리 답변을 하자면, Visual Studio 내에서는 sos.dll 확장 명령어를 수행할 수 있는 방법이 없습니다. 이에 대해서는 이미 예전에 글을 쓴 것이 있으니 참고하시고,

Visual Studio 2013에서의 sos.dll 사용 제한
; https://www.sysnet.pe.kr/2/0/2875

어쨌든 Visual Studio 내에서는 안 되지만 외부 디버거, 예를 들어 windbg의 힘을 빌리면 가능합니다. 여기서 잠시 의아해하시는 분들이 있을 텐데요. 일반적으로 디버거는 2개 이상 연결이 안 되기 때문에 일단 Visual Studio에서 디버깅을 수행하고 있으면 해당 프로세스에 windbg로는 다시 attach시킬 수 없습니다.

실제로 해보면 다음과 같은 오류가 발생하는데요,

Could not attach to process 70856, NTSTATUS 0xC0000048

The process that you are attempting to attach to is already being debugged. Only one debugger can be invasively attached to a process at a time. A non-invasive attach is still possible when another debugger is attached.


그런데, 오류 메시지를 가만 보면 "Non-invasive attach"는 가능하다고 나옵니다. 그렇습니다, 바로 저 방식을 이용해 windbg를 비주얼 스튜디오가 디버깅 중인 프로세스에 연결할 수 있는데 이때 "File" / "Attach to a Process (단축키: F6)"를 눌러 뜨는 대화창에서,

vs_plus_sos_debug_1.png

좌측 하단의 "Noninvasive" 체크 박스를 설정하면 됩니다.

이렇게 해서 연결하면 Visual Studio는 잠시 디버깅을 할 수 없고 windbg로만 디버깅 기능이 동작합니다. 따라서 ".loadby sos clr" 등을 이용한 확장 명령어와 함께 다양한 windbg 명령어를 활용할 수 있습니다.

모든 제어를 마친 후 다시 Visual Studio에 디버깅 기능을 돌려주고 싶다면 "Debug" / "Detach Debuggee" 메뉴를 선택하거나 명령 프롬프트에서 "qd"로 빠져나오면 됩니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]


donaricano-btn



[최초 등록일: ]
[최종 수정일: 1/15/2020 ]

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

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
12196정성태3/17/2020803오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/17/20201026.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/20201183오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/2020881개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행
12192정성태3/14/20201086개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/20201704개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/2020632오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/20201809개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태9/24/20201013Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/2020745오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/2020857오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
12185정성태3/11/2020766오류 유형: 603. The browser service was unable to retrieve a list of servers from the browser master...
12184정성태3/11/20201185오류 유형: 602. Automatic certificate enrollment for local system failed (0x800706ba) The RPC server is unavailable. [3]
12183정성태3/12/2020890오류 유형: 601. Warning: DsGetDcName returned information for \\[...], when we were trying to reach [...].
12182정성태3/11/20201079.NET Framework: 901. C# Windows Forms - Vista/7 이후의 Progress Bar 업데이트가 느린 문제파일 다운로드1
12181정성태3/11/20201162기타: 76. 재현 가능한 최소한의 예제 프로젝트란? - 두 번째 예제파일 다운로드1
12180정성태3/10/2020665오류 유형: 600. "Docker Desktop for Windows" - EXPOSE 포트가 LISTENING 되지 않는 문제
12179정성태3/10/20201036개발 환경 구성: 481. docker - PostgreSQL 컨테이너 실행
12178정성태10/28/2020978개발 환경 구성: 480. Linux 운영체제의 docker를 위한 tcp 바인딩 추가 [1]
12177정성태3/9/2020971개발 환경 구성: 479. docker - MySQL 컨테이너 실행
12176정성태3/9/2020742개발 환경 구성: 478. 파일의 (sha256 등의) 해시 값(checksum) 확인하는 방법
12175정성태3/8/20201051개발 환경 구성: 477. "Docker Desktop for Windows"의 "Linux Container" 모드를 위한 tcp 바인딩 추가
12174정성태3/8/20201127개발 환경 구성: 476. DockerDesktopVM의 파일 시스템 접근 [2]
12173정성태3/8/20201135개발 환경 구성: 475. docker - SQL Server 2019 컨테이너 실행 [1]
12172정성태3/8/20201953개발 환경 구성: 474. docker - container에서 root 권한 명령어 실행(sudo)
12171정성태3/6/20201008VS.NET IDE: 143. Visual Studio - ASP.NET Core Web Application의 "Enable Docker Support" 옵션으로 달라지는 점
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...