Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 4. VC++ 8.0 원격 디버깅 구성 - Side-by-Side DLL 문제. [링크 복사], [링크+제목 복사],
조회: 23693
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12364정성태10/11/202019474.NET Framework: 948. C# 9.0 - (2) localsinit 플래그 내보내기 무시(Suppress emitting localsinit flag)파일 다운로드1
12363정성태10/11/202021169.NET Framework: 947. C# 9.0 - (1) 대상으로 형식화된 new 식(Target-typed new expressions) [2]파일 다운로드1
12362정성태10/11/202017739VS.NET IDE: 151. Visual Studio 2019에 .NET 5 rc/preview 적용하는 방법
12361정성태10/11/202019754.NET Framework: 946. C# 9.0을 위한 개발 환경 구성
12360정성태10/8/202014952오류 유형: 666. The type or namespace name '...' does not exist in the namespace 'Microsoft.VisualStudio.TestTools' (are you missing an assembly reference?)
12359정성태10/7/202017194오류 유형: 665. Windows - 재부팅 후 iSCSI 연결이 끊기는 문제
12358정성태10/7/202018088오류 유형: 664. Web Deploy 설치 시 "A newer version of Microsoft Web Deploy 3.6 was found on this machine." 오류 [3]
12357정성태10/7/202015713오류 유형: 663. 이벤트 로그 - The storage optimizer couldn't complete retrim on New Volume
12356정성태10/7/202031333오류 유형: 662. ASP.NET Core와 500.19, 500.21 오류 (0x8007000d)
12355정성태10/3/202014877오류 유형: 661. Hyper-V Linux VM의 Internal 유형의 가상 Switch에 대한 IP 연결이 되지 않는 경우
12354정성태10/2/202028892오류 유형: 660. Web Deploy (msdeploy.axd) 실행 시 오류 기록 [1]
12353정성태10/2/202018341개발 환경 구성: 518. 비주얼 스튜디오에서 IIS 웹 서버로 "Web Deploy"를 이용해 배포하는 방법
12352정성태10/2/202019580개발 환경 구성: 517. Hyper-V Internal 네트워크에 NAT을 이용한 인터넷 연결 제공
12351정성태10/2/202018034오류 유형: 659. Nox 실행이 안 되는 경우 - Unable to bind to the underlying transport for ...
12350정성태9/25/202022460Windows: 175. 윈도우 환경에서 클라이언트 소켓의 최대 접속 수 [2]파일 다운로드1
12349정성태9/25/202016626Linux: 32. Ubuntu 20.04 - docker를 위한 tcp 바인딩 추가
12348정성태9/25/202017634오류 유형: 658. 리눅스 docker - Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock
12347정성태9/25/202033175Windows: 174. WSL 2의 네트워크 통신 방법 [4]
12346정성태9/25/202016638오류 유형: 657. IIS - http://localhost 방문 시 Service Unavailable 503 오류 발생
12345정성태9/25/202016200오류 유형: 656. iisreset 실행 시 "Restart attempt failed." 오류가 발생하지만 웹 서비스는 정상적인 경우파일 다운로드1
12344정성태9/25/202018117Windows: 173. 서비스 관리자에 "IIS Admin Service"가 등록되어 있지 않다면?
12343정성태9/24/202029166.NET Framework: 945. C# - 닷넷 응용 프로그램에서 메모리 누수가 발생할 수 있는 패턴 [5]
12342정성태9/24/202019165디버깅 기술: 171. windbg - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법
12341정성태9/23/202017215.NET Framework: 944. C# - 인스턴스가 살아 있어 메모리 누수가 발생하고 있는지 확인하는 방법파일 다운로드1
12340정성태9/23/202016861.NET Framework: 943. WPF - WindowsFormsHost를 담은 윈도우 생성 시 메모리 누수
12339정성태9/21/202017040오류 유형: 655. 코어 모드의 윈도우는 GUI 모드의 윈도우로 교체가 안 됩니다.
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...