Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 30. windbg ".loadby sos" 명령어 [링크 복사], [링크+제목 복사],
조회: 31957
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 7개 있습니다.)
(시리즈 글이 3개 있습니다.)
디버깅 기술: 30. windbg ".loadby sos" 명령어
; https://www.sysnet.pe.kr/2/0/943

디버깅 기술: 158. Visual Studio로 디버깅 시 sos.dll 확장 명령어를 (비롯한 windbg의 다양한 기능을) 수행하는 방법
; https://www.sysnet.pe.kr/2/0/12116

디버깅 기술: 179. 윈도우용 .NET Core 3 이상에서 Windbg의 sos 사용법
; https://www.sysnet.pe.kr/2/0/12641




windbg ".loadby sos" 명령어

.NET Framework 버전별 / 플랫폼별로 구분하여 SOS.dll 확장을 선택해서 로드해야 하는 불편함을 개선시킨 명령어입니다. 보통 웹상의 자료에 보면, 아래와 같이 2개의 명령어를 보게 되는데요.

0:030> .loadby sos clr

또는,

0:030> .loadby sos mscorwks

".loadby sos clr"은 .NET 4.0 응용 프로그램을 디버깅할 때 사용할 수 있고, ".loadby sos mscorwks"는 .NET 3.5 이하의 응용 프로그램을 디버깅할 때 사용가능합니다.

만약, .NET 3.5 응용 프로그램을 디버깅하는 데, ".loadby sos clr"을 실행하면 다음과 같은 식으로 오류가 발생합니다.

0:030> .loadby sos clr
Unable to find module 'clr'

** 만약 4.0을 대상으로 ".loadby sos mscorwks"를 해도 역시 "Unable to find module 'mscorwks'" 오류 발생.

왜냐하면, ".loadby sos [모듈이름]"이라는 명령어는 지정된 모듈을 기반으로 어떤 버전의 같은 폴더에 위치한 sos.dll을 찾아서 로드하는 명령어이기 때문인데, .NET 3.5 응용 프로그램의 로드된 모듈 목록에는 "clr.dll"이 없으므로 그와 같은 오류가 발생하는 것입니다.

그런 연유로 인해, 사실 반드시 "clr" 또는 "mscorwks"일 필요도 없습니다. 예를 들어, .NET 4.0의 경우 ".loadby sos clrjit"라고 해도 되고, .NET 3.5의 경우 ".loadby sos mscorjit"라고 해도 됩니다.

또한, 대상 프로세스를 디버깅하는 데 있어 아직 sos.dll과 같은 폴더에 있는 닷넷 관련 모듈들이 버전을 판단할 수 있는 근거가 될 만한 managed 모듈들이 올라오지 않은 상태에서 ".loadby sos ..." 명령어를 내리게 되면 "Unable to find module..." 오류가 발생하게 됩니다. 즉, 적어도 "[모듈 이름]"으로 명시한 DLL이 프로세스에 올라와 있어야 합니다.





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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/28/2021]

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

비밀번호

댓글 작성자
 



2011-03-04 09시26분
Problems running sos-commands
; (broken) http://blogs.msdn.com/b/johan/archive/2011/03/04/problems-running-sos-commands.aspx
정성태
2017-10-06 10시13분
정성태

... 166  167  168  169  170  171  172  173  174  175  176  177  178  [179]  180  ...
NoWriterDateCnt.TitleFile(s)
544정성태11/25/200723429오류 유형: 48. VS.NET 2008 설치 오류 - Error code 1602 [5]
543정성태11/25/200726490개발 환경 구성: 31. ROBOCOPY XP026 버전 [1]
542정성태11/3/200741541VS.NET IDE: 55. XML/XSLT로 구현하는 매크로 확장 [5]파일 다운로드2
538정성태10/11/200727864스크립트: 10. VBScript - "Sub를 호출할 때는 괄호를 사용할 수 없습니다." [2]
537정성태9/28/200736613개발 환경 구성: 30. 64비트 OS에서의 ChartFX 라이선스 문제
536정성태9/12/200733594.NET Framework: 97. WCF : netTcpBinding에서의 각종 Timeout 값 설명 [11]
535정성태9/11/200730966.NET Framework: 96. WCF - PerSession에서의 클라이언트 연결 관리 [5]
534정성태9/3/200726597개발 환경 구성: 29. VHD 파일 크기 줄이기
533정성태9/2/200729159개발 환경 구성: 28. CA 서비스 - 사용자 정의 템플릿 유형 추가
532정성태9/2/200731573개발 환경 구성: 27. AD CA에서 Code Signing 인증서 유형 추가 방법
531정성태9/2/200727401.NET Framework: 95. WCF에서의 DataTable 사용
530정성태9/1/200723839.NET Framework: 94. WCF 예외에 대한 시행착오
529정성태8/31/200726834.NET Framework: 93. WCF - DataContract와 KnownType 특성 [1]
528정성태8/30/200721355오류 유형: 47. VPC - 네트워크 어댑터 MAC 주소 중복 오류
527정성태8/30/200731583Team Foundation Server: 20. 잠긴 파일을 강제로 해제 [2]
526정성태8/29/200721417오류 유형: 46. VS.NET 2008 - ASP.NET 디버깅 : Strong name validation failed.
525정성태8/27/200723603VS.NET IDE: 54. VS.NET 2008 - 새롭게 도입되는 XSD Schema Designer
524정성태8/23/200741222오류 유형: 45. 요청한 작업은, 사용자가 매핑한 구역이 열려 있는...
523정성태8/16/200723845VS.NET IDE: 53. VS.NET 2008 - 서비스 참조 시 기존 데이터 컨테이너 DLL 사용
522정성태8/13/200727479VS.NET IDE: 52. VS.NET 2008 - WCF를 위한 디버깅 환경 개선
521정성태8/8/200727397.NET Framework: 92. XmlSerializer 생성자의 실행 속도를 올리는 방법 - 두 번째 이야기 [3]
520정성태8/7/200722633VS.NET IDE: 51. Visual Studio 2008 베타 2 설치
519정성태7/27/200728996오류 유형: 44. System.BadImageFormatException [2]
518정성태7/26/200730073오류 유형: 43. System.ComponentModel.LicenseException [1]
517정성태7/19/200718326개발 환경 구성: 26. VPC - 일반 사용자 계정으로 구동
516정성태7/19/200721553오류 유형: 42. TFS - Error loading menu: Index was outside the bounds of the array [2]
... 166  167  168  169  170  171  172  173  174  175  176  177  178  [179]  180  ...