Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 4. VC++ 8.0 원격 디버깅 구성 - Side-by-Side DLL 문제. [링크 복사], [링크+제목 복사],
조회: 24994
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

오랜만에, 제 컴퓨터에서 원격 XP 컴퓨터를 대상으로 원격 디버깅을 구성하게 되었습니다.
Internet Explorer에서 활성화되는 COM 개체이기 때문에, XP 컴퓨터에 regsvr32.exe로 등록을 하려고 했는데... 이게 왠일입니까? ^^; VC++ 8.0에서의 Side-by-Side(이후, SxS로 지칭) 지원과 함께 XP/2003에서의 SxS 기능이 결합되어 정상적으로 등록이 안되는 것입니다.

등록을 시도하면 아래와 같은 오류 화면이 나옵니다.

등록 오류

LoadLibrary("...") failed - This application has failed to start 
because the application configuration is incorrect. Reinstalling the application may fix this problem.

좀 더 자세한 오류를 보기 위해서 depends.exe로 해당 DLL을 열어보니 아래와 같은 오류 화면이 나옵니다.

Depends.exe에서 확인

Error: The Side-by-Side configuration information in "C:\...DLL" contains errors. 
This application has failed to start because the application configuration is incorrect.
Reinstalling the application may fix this problem (14001).
Warning: At least one module has an unresolved import due to a missing export function in a delay-load dependent module.

또한, 이벤트 로그에도 다음과 같은 오류 3개가 차례대로 나타나게 됩니다.

오류 1:
Generate Activation Context failed for C:\...\Test.dll. 
Reference error message: The operation completed successfully.

오류 2:
Resolve Partial Assembly failed for Microsoft.VC80.DebugCRT. 
Reference error message: The referenced assembly is not installed on your system.

오류 3:
Dependent Assembly Microsoft.VC80.DebugCRT could not be found and 
Last Error was The referenced assembly is not installed on your system.

어허... 세월이 얼마나 흘렀다고 그 얼마 안되는 기간에 이런 변화가 있었는지... ^^;

해결 방법은 간단합니다. 해당 시스템에 - 위에서는 Microsoft.VC80.DebugCRT 관련 DLL을 정상적으로 활성화 시킬 수 없어서 발생 - 적절하게 관련 DLL들을 C:\Windows\WinSxS 폴더에 설정해 주거나, 아니면 해당 COM 개체가 있는 폴더에 관련 DLL 및 Manifest 파일을 넣어주면 됩니다. 전자의 방법은... ^^ 나중에 필요하면 다시 알아보고 설명드릴테니... 여기서는 쉬운 후자의 방법을 택해서 일단 원격 디버깅을 계속 해나가도록 하겠습니다.

문제 해결을 위해 "Microsoft.VC80.DebugCRT"에 해당하는 DLL과 Manifest 파일이 필요한데요. Visual Studio 2005가 설치된 개발자 PC에서 아래와 같은 폴더로 이동하면 4개의 파일을 볼 수가 있습니다.

폴더 - C:\Program Files\Microsoft Visual Studio 8\VC\redist\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT

파일 - Microsoft.VC80.DebugCRT.manifest
파일 - msvcm80d.dll
파일 - msvcp80d.dll
파일 - msvcr80d.dll

위의 4개 파일을 COM 개체가 있는 폴더에 그대로 복사합니다. 대강 아래와 같은 모습이 되겠지요.

정상적으로 구성된 파일들

자, 이제 기존에 했던 것처럼, regsvr32.exe를 하면 정상적으로 등록이 되는 것을 확인할 수 있습니다.






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 




... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1663정성태4/28/201420023오류 유형: 226. Visual Studio - We were unable to establish the connection because it is configured for user
1662정성태4/28/201424623개발 환경 구성: 220. supportedRuntime 설정을 위한 app.config Transformation [1]
1661정성태4/26/201421142.NET Framework: 432. WPF - System.Windows.Data Error: 47 : XmlDataProvider has inline XML that does not explicitly set its XmlNamespace (xmlns="").
1660정성태4/25/201429046VC++: 77. C++ 숫자형 값이 범위를 벗어나는 경우의 출력 사례 모음
1659정성태4/17/201429142.NET Framework: 431. .NET EXE 파일을 닷넷 프레임워크 버전에 상관없이 실행할 수 있을까요? [5]
1658정성태4/17/201420990.NET Framework: 430. C#에서 사용자 정의 예약어가 가능할까요? [1]
1657정성태4/10/201441306.NET Framework: 429. C# - 유니코드 한글 문자열을 ks_c_5601-1987로 변환하는 방법 [3]파일 다운로드1
1656정성태3/19/201424466오류 유형: 225. regsvcs 등록 시 0x80040153 오류
1655정성태3/19/201424597Windows: 92. Thumbs.db 파일이 삭제 안 되는 문제
1654정성태3/19/201426662개발 환경 구성: 219. SOS.dll 확장 모듈을 버전 별로 구하는 방법 [4]
1653정성태3/13/201421384.NET Framework: 428. .NET Reflection으로 다차원/Jagged 배열을 구분하는 방법
1652정성태3/12/201422270VC++: 76. Direct Show를 사용하는 다른 프로그램의 필터 그래프를 graphedt.exe에서 확인하는 방법파일 다운로드1
1651정성태3/11/201426165.NET Framework: 427. C# 컴파일러는 변수를 초기화시키지 않을까요?
1650정성태3/6/201427073VC++: 75. Visual C++ 컴파일 오류 - Cannot use __try in functions that require object unwinding [1]파일 다운로드1
1649정성태3/5/201421545기타: 44. BTN 스토어 앱 개인정보 보호 정책 안내
1648정성태3/5/201421942개발 환경 구성: 218. 스토어 앱 인증 실패 - no privacy statement
1647정성태3/3/201423265오류 유형: 224. 스카이드라이브 비정상 종료 - Error 0x80040A41: No error description available
1646정성태3/3/201432583오류 유형: 223. Microsoft-Windows-DistributedCOM 10016 이벤트 로그 에러 [1]
1645정성태3/1/201422326기타: 43. 마이크로소프트 MVP들이 모여 전국 세미나를 엽니다.
1644정성태2/26/201429369.NET Framework: 426. m3u8 스트리밍 파일을 윈도우 8.1 Store App에서 재생하는 방법파일 다운로드1
1643정성태2/25/201425146오류 유형: 222. 윈도우 8 Store App - APPX1204 SignTool Error: An unexpected internal error has occurred [1]
1642정성태2/25/201429823Windows: 91. 한글이 포함된 사용자 프로파일 경로 변경 [2]
1641정성태2/24/201426471기타: 42. 클래스 설명 [5]
1640정성태2/24/201447539.NET Framework: 425. C# - VLC(ActiveX) 컨트롤을 레지스트리 등록 없이 사용하는 방법 [15]
1639정성태2/23/201423248기타: 41. BBS 스토어 앱 개인정보 보호 정책 안내
1638정성태2/18/201446051Windows: 90. 실행 파일로부터 관리자 요구 권한을 제거하는 방법(부제: 크랙 버전을 보다 안전하게 실행하는 방법) [8]
... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...