서버 유형의 COM+ 사용 시 0x80080005(Server execution failed) 오류 발생
서버 유형의, 즉 dllhost.exe로 호스팅되는 COM+ 개체를 생성하려고 했는데 다음과 같은 예외가 발생합니다.
System.Runtime.InteropServices.COMException
HResult=0x80080005
Message=Server execution failed
Server execution failed
Source=mscorlib
StackTrace:
at System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo)
at System.EnterpriseServices.Thunk.Proxy.CoCreateObject(Type serverType, Boolean bQuerySCInfo, Boolean& bIsAnotherProcess, String& uri)
at System.EnterpriseServices.ServicedComponentProxyAttribute.CreateInstance(Type serverType)
at System.Runtime.Remoting.Activation.ActivationServices.IsCurrentContextOK(RuntimeType serverType, Object[] props, Boolean bNewObj)
at ConsoleApp1.Program.Main(String[] args)
이런 경우, Server 유형의 COM+가 시작하지 못한 것인데 "
Component Services"에 등록된 해당 COM+를 명시적으로 "Start" 시켜 보면 동일한 에러와 함께 이벤트 로그를 보라는 메시지가 나옵니다.
Catalog Error
An error occurred while processing the last operation.
Error code 80080005 - Server execution failed
The event log may contain additional troubleshooting information.
그래서 이벤트 로그에 보면 이런 오류 항목이 나옵니다.
Log Name: Application
Source: Microsoft-Windows-Complus
Date: ...
Event ID: 4829
Task Category: Executive
Level: Error
Keywords: Classic
User: N/A
Computer: ...
Description:
A COM+ service (such as Queued Components or Compensating Resource Manager) failed to start. The service GUID and HRESULT are: {F27FBEFA-4970-43AF-9192-1DF990B6B898}
Server Application ID: {FC3BD2AA-7BBE-41F7-9CAC-73F65735A7F9}
Server Application Instance ID:
{2BA5A7D5-952A-4C25-93E3-AEFB1A7B10C3}
Server Application Name: TEST COMPLUS APP
The serious nature of this error has caused the process to terminate.
Error Code = 0x80070002 : The system cannot find the file specified.
COM+ Services Internals Information:
File: com\complus\src\comsvcs\srgtapi\csrgtserv.cpp, Line: 63
Comsvcs.dll file version: ENU 2001.12.10941.16384 shp
"0x80070002: The system cannot find the file specified." 메시지를 볼 수 있는데요, 실제로 해당 구성 요소에서 참조하고 있는 DLL이 GAC에 등록돼 있지 않아서 발생한 것입니다. 관련해서 다음의 도움말도 함께 보시고.
Error when you start many COM+ applications: Error code 80080005 -- server execution failed
; https://docs.microsoft.com/en-us/troubleshoot/windows-server/application-management/error-8008005-when-start-complus-applications
또는, 이벤트 로그에 이런 오류가 남을 수 있습니다.
Log Name: Application
Source: Microsoft-Windows-Complus
Date: ...
Event ID: 4833
Task Category: Executive
Level: Error
Keywords: Classic
User: N/A
Computer: ...
Description:
The initialization of the COM+ surrogate failed -- the CApplication object failed to initialize. {FC3BD2AA-7BBE-41F7-9CAC-73F65735A7F9}
Server Application ID: {FC3BD2AA-7BBE-41F7-9CAC-73F65735A7F9}
Server Application Instance ID:
{A447295F-EDD2-47CE-9C60-7FEF63643E4E}
Server Application Name: TEST COMPLUS APP
The serious nature of this error has caused the process to terminate.
Error Code = 0x80131500 :
COM+ Services Internals Information:
File: com\complus\src\comsvcs\srgtapi\csrgtserv.cpp, Line: 372
Comsvcs.dll file version: ENU 2001.12.10941.16384 shp
이 오류의 원인은 매우 다양할 수 있는데요, 검색해 보면 다음의 자료에서처럼,
Event ID - 4833
; https://kb.eventtracker.com/evtPass/evtPages/EventId_4833_Microsoft-Windows-Complus_67050.asp
리소스 부족도 그럴 수 있겠지만, COM+가 구현한
IProcessInitializer.
Startup 함수에서 예외가 발생할 때도 저런 오류를 볼 수 있습니다.
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]