Microsoft MVP성태의 닷넷 이야기
오류 유형: 474. 닷넷 COM+ - Failed to load the runtime. [링크 복사], [링크+제목 복사],
조회: 20314
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

닷넷 COM+ - Failed to load the runtime.

닷넷 COM+ 사용 시 다음과 같은 오류가 발생한다면?

Server Error in '/' Application.
--------------------------------------------------------------------------------

Failed to load the runtime. (Exception from HRESULT: 0x80131700) 
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: System.Runtime.InteropServices.COMException: Failed to load the runtime. (Exception from HRESULT: 0x80131700)

Source Error: 

An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.  

Stack Trace: 

[COMException (0x80131700): Failed to load the runtime. (Exception from HRESULT: 0x80131700)]
   System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo) +0
   System.Runtime.InteropServices.Marshal.ThrowExceptionForHR(Int32 errorCode) +16
   System.EnterpriseServices.Thunk.Proxy.CoCreateObject(Type serverType, Boolean bQuerySCInfo, Boolean& bIsAnotherProcess, String& uri) +301
   System.EnterpriseServices.ServicedComponentProxyAttribute.CreateInstance(Type serverType) +195
   System.Runtime.Remoting.Activation.ActivationServices.IsCurrentContextOK(RuntimeType serverType, Object[] props, Boolean bNewObj) +85
   WebSiteTest.ComPlusServerTest.Page_Load(Object sender, EventArgs e) in d:\WebSiteTest4\ComPlusServerTest.aspx.cs:115
   System.Web.UI.Control.OnLoad(EventArgs e) +104
   System.Web.UI.Control.LoadRecursive() +112
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +2213

--------------------------------------------------------------------------------
Version Information: Microsoft .NET Framework Version:4.0.30319; ASP.NET Version:4.7.2623.0 

만약 COM+가 "서버 활성화" 유형이고 해당 DLL이 CLR 2 기반으로 빌드된 것이라면 저런 오류가 발생할 수 있습니다. 일례로, COM+의 dllhost.exe에서 DLL을 활성화시킬 때 DLL의 Target Framework 버전이 2.0 ~ 3.5라면 dllhost.exe 내에 .NET Framework 2.0 ~ 3.5에 해당하는 런타임을 올리려 할 것입니다. 문제는, 해당 운영체제에 .NET 3.5가 설치되어 있지 않은 경우 저런 식으로 "Failed to load the runtime" 예외가 발생하는 것입니다.

문제의 원인을 알았으니 해결도 간단합니다.

그냥 .NET Framework 3.5를 설치하든가, 해당 COM+ DLL을 .NET Framework 4.0 이상의 버전으로 다시 빌드해 배포하면 됩니다.




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







[최초 등록일: ]
[최종 수정일: 8/8/2018]

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

비밀번호

댓글 작성자
 



2019-08-19 07시44분
[지나갑니다.] 혹시 윈도우10 환경에서 닷넷 4.6 혹은 4.7만 설치되어있을 경우에도 위의 에러가 발생할 수 있을까요?
[guest]

... [106]  107  108  109  110  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11305정성태9/12/201722993개발 환경 구성: 334. 기존 프로젝트를 Visual Studio를 이용해 Github의 신규 생성된 repo에 올리는 방법 [1]
11304정성태9/11/201719937개발 환경 구성: 333. 3ds Max를 Hyper-V VM에서 실행하는 방법
11303정성태9/11/201723499개발 환경 구성: 332. Inno Setup 파일의 관리자 권한을 제거하는 방법
11302정성태9/11/201719313개발 환경 구성: 331. SQL Server Express를 위한 방화벽 설정
11301정성태9/11/201717586오류 유형: 420. SQL Server Express 연결 오류 - A network-related or instance-specific error occurred while establishing a connection to SQL Server.
11300정성태9/10/201722355.NET Framework: 681. dotnet.exe - run, exec, build, restore, publish 차이점 [3]
11299정성태9/9/201721081개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
11298정성태9/8/201724555VC++: 119. EnumProcesses / EnumProcessModules API 사용 시 주의점 [1]
11297정성태9/8/201721114디버깅 기술: 96. windbg - 풀 덤프에 포함된 모든 닷넷 모듈을 파일로 저장하는 방법
11296정성태9/8/201723871웹: 36. Edge - "이 웹 사이트는 이전 기술에서 실행되며 Internet Explorer에서만 작동합니다." 끄는 방법
11295정성태9/7/201721689디버깅 기술: 95. Windbg - .foreach 사용법
11294정성태9/4/201721299개발 환경 구성: 329. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 [1]
11293정성태9/4/201722006개발 환경 구성: 328. Visual Studio(devenv.exe)를 배치 파일(.bat)을 통해 실행하는 방법
11292정성태9/4/201720128오류 유형: 419. Cannot connect to WMI provider - Invalid class [0x80041010]
11291정성태9/3/201721365개발 환경 구성: 327. 아파치 서버 2.4를 위한 mod_aspdotnet 마이그레이션
11290정성태9/3/201725191개발 환경 구성: 326. 아파치 서버에서 ASP.NET을 실행하는 mod_aspdotnet 모듈 [2]
11289정성태9/3/201722860개발 환경 구성: 325. GAC에 어셈블리 등록을 위해 gacutil.exe을 사용하는 경우 주의 사항
11288정성태9/3/201719602개발 환경 구성: 324. 윈도우용 XAMPP의 아파치 서버 구성 방법
11287정성태9/1/201728660.NET Framework: 680. C# - 작업자(Worker) 스레드와 UI 스레드 [11]
11286정성태8/28/201716193기타: 67. App Privacy Policy
11285정성태8/28/201724691.NET Framework: 679. C# - 개인 키 보안의 SFTP를 이용한 파일 업로드파일 다운로드1
11284정성태8/27/201722902.NET Framework: 678. 데스크톱 윈도우 응용 프로그램에서 UWP 라이브러리를 이용한 비디오 장치 열람하는 방법 [1]파일 다운로드1
11283정성태8/27/201718531오류 유형: 418. CSS3117: @font-face failed cross-origin request. Resource access is restricted.
11282정성태8/26/201720298Math: 22. 행렬로 바라보는 피보나치 수열
11281정성태8/26/201722519.NET Framework: 677. Visual Studio 2017 - NuGet 패키지를 직접 참조하는 PackageReference 지원 [2]
11280정성태8/24/201719900디버깅 기술: 94. windbg - 풀 덤프에 포함된 모든 모듈을 파일로 저장하는 방법
... [106]  107  108  109  110  111  112  113  114  115  116  117  118  119  120  ...