Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).

이런 유의 오류가 발생하면서,

Server Error in '/' Application.
The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
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.EnterpriseServices.ServicedComponentException: The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).

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:

[ServicedComponentException: The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).]
   System.EnterpriseServices.ServicedComponentProxy.FilterConstructors() +115
   System.EnterpriseServices.ServicedComponentProxyAttribute.CreateInstance(Type serverType) +752
   System.Runtime.Remoting.Activation.ActivationServices.IsCurrentContextOK(Type serverType, Object[] props, Boolean bNewObj) +67
   TestWebApp.ComPlusServerTest.Page_Load(Object sender, EventArgs e) in C:\Temp\TestWebApp\ComPlusServerTest.aspx.cs:63
   System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
   System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +43
   System.Web.UI.Control.OnLoad(EventArgs e) +91
   System.Web.UI.Control.LoadRecursive() +74
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1716

메시지에 따라 regsvcs.exe로 COM+ 객체를 등록할 때 다음의 오류 메시지가 나오는 경우,

The following installation error occurred:
1: One or more of the components being installed are already registered as 64 bit components in the target application. You must install the 32 bit versions of the components being installed in a diff
erent COM+ application, or delete the existing 64 bit versions of the components being installed from the target COM+ application prior to attempting install of the 32 bit versions. COM+ applications
cannot contain bit neutral components.


아마도 .NET COM+ DLL을 이미 COM+에 64비트 Library 유형으로 등록한 상태에서 다시 32비트로도 COM+에 등록하는 경우일 것입니다.

어쩔 수 없습니다. 만약 저런 상황이 나오면 해당 COM+ 객체를 64비트와 32비트에 대해 ApplicationName 등의 속성을 별도 분리해서 컴파일해야 합니다.

#if DEF_X86BUILD
[assembly: ApplicationName("MyComponentLibraryX86")]
#else
[assembly: ApplicationName("MyComponentLibrary")]
#endif

또한 각각의 Library 유형에서 서비스하게 되는 COM+ 객체의 GUID도 바꿔서,

#if DEF_X86BUILD
[System.Runtime.InteropServices.Guid("F873A6B6-ADC0-4C51-AF0F-FC2F88E466A6")]
#else
[System.Runtime.InteropServices.Guid("BDC0B215-0BA0-465A-A0C8-7CD5C7120ECF")]
#endif
public class MyComponentLibrary : ServicedComponent
{
    // ...[생략]...
}

빌드하면, 이후 해당 COM+를 사용하는 32/64비트 응용 프로그램은 정상적으로 객체를 등록/활성화할 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 3/17/2020]

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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12313정성태9/6/202012083개발 환경 구성: 509. Logstash - 사용자 정의 grok 패턴 추가를 이용한 IIS 로그 처리
12312정성태9/5/202015967개발 환경 구성: 508. Logstash 기본 사용법 [2]
12311정성태9/4/202011184.NET Framework: 937. C# - 간단하게 만들어 보는 리눅스의 nc(netcat), json_pp 프로그램 [1]
12310정성태9/3/202010467오류 유형: 644. Windows could not start the Elasticsearch 7.9.0 (elasticsearch-service-x64) service on Local Computer.
12309정성태9/3/202010212개발 환경 구성: 507. Elasticsearch 6.6부터 기본 추가된 한글 형태소 분석기 노리(nori) 사용법
12308정성태9/2/202011487개발 환경 구성: 506. Windows - 단일 머신에서 단일 바이너리로 여러 개의 ElasticSearch 노드를 실행하는 방법
12307정성태9/2/202012230오류 유형: 643. curl - json_parse_exception / Invalid UTF-8 start byte
12306정성태9/1/202010401오류 유형: 642. SQL Server 시작 오류 - error code 10013
12305정성태9/1/202011258Windows: 172. "Administered port exclusions"이 아닌 포트 범위 항목을 삭제하는 방법
12304정성태8/31/202010217개발 환경 구성: 505. 윈도우 - (네트워크 어댑터의 우선순위로 인한) 열거되는 IP 주소 순서를 조정하는 방법
12303정성태8/30/202010391개발 환경 구성: 504. ETW - 닷넷 프레임워크 기반의 응용 프로그램을 위한 명령행 도구 etrace 소개
12302정성태8/30/202010276.NET Framework: 936. C# - ETW 관련 Win32 API 사용 예제 코드 (5) - Private Logger파일 다운로드1
12301정성태8/30/202010623오류 유형: 641. error MSB4044: The "Fody.WeavingTask" task was not given a value for the required parameter "IntermediateDir".
12300정성태8/29/202010008.NET Framework: 935. C# - ETW 관련 Win32 API 사용 예제 코드 (4) CLR ETW Consumer파일 다운로드1
12299정성태8/27/202010949.NET Framework: 934. C# - ETW 관련 Win32 API 사용 예제 코드 (3) ETW Consumer 구현파일 다운로드1
12298정성태8/27/202010690오류 유형: 640. livekd - Could not resolve symbols for ntoskrnl.exe: MmPfnDatabase
12297정성태8/25/20209912개발 환경 구성: 503. SHA256 테스트 인증서 생성 방법
12296정성태8/24/202010302.NET Framework: 933. C# - ETW 관련 Win32 API 사용 예제 코드 (2) NT Kernel Logger파일 다운로드1
12295정성태8/24/20209727오류 유형: 639. Bitvise - Address is already in use; bind() in ListeningSocket::StartListening() failed: Windows error 10013: An attempt was made to access a socket ,,,
12293정성태8/24/202011051Windows: 171. "Administered port exclusions" 설명
12292정성태8/20/202012391.NET Framework: 932. C# - ETW 관련 Win32 API 사용 예제 코드 (1)파일 다운로드2
12291정성태8/15/202011347오류 유형: 638. error 1297: Device driver does not install on any devices, use primitive driver if this is intended.
12290정성태8/11/202012003.NET Framework: 931. C# - IP 주소에 따른 국가별 위치 확인 [8]파일 다운로드1
12289정성태8/6/20209486개발 환경 구성: 502. Portainer에 윈도우 컨테이너를 등록하는 방법
12288정성태8/5/20209536오류 유형: 637. WCF - The protocol 'net.tcp' does not have an implementation of HostedTransportConfiguration type registered.
12287정성태8/5/20209995오류 유형: 636. C# - libdl.so를 DllImport로 연결 시 docker container 내에서 System.DllNotFoundException 예외 발생
... 46  47  48  49  50  51  52  [53]  54  55  56  57  58  59  60  ...