Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 4. VC++ 8.0 원격 디버깅 구성 - Side-by-Side DLL 문제. [링크 복사], [링크+제목 복사],
조회: 23696
글쓴 사람
정성태 (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)
12211정성태4/27/202019275개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
12210정성태4/20/202020721.NET Framework: 903. .NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션 [1]파일 다운로드1
12209정성태4/13/202017424오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
12208정성태4/12/202015995Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
12207정성태4/2/202015849스크립트: 19. Windows PowerShell의 NonInteractive 모드
12206정성태4/2/202018448오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/202015114스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/202015129스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202017965오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202021214개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202018454오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202018542VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/202016182오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202019537오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202018838VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202015962오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202018277.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202021004오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202017946개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202019980개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202021064개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202015644오류 유형: 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/202021249개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202026036Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202015620오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/202017408오류 유형: 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.
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...