Microsoft MVP성태의 닷넷 이야기
COM+ 의 활성화 상태... [링크 복사], [링크+제목 복사],
조회: 11323
글쓴 사람
탑 (develtop at empal.com)
홈페이지
첨부 파일
 

이전 vb 로 작성되는 com+ 서비스용을 닷넷용으로 첨 해봅니다.

COM+ 로 소스를 작성 하였습니다.
그런데 객체를 사용하고 난 후 구성요소 서비스에서 계속 활성화 상태로 남아 있는데...
어떤 문제인지 ....

요지는...

아래와 같이 A, B 가 있다고 할적에 모두 COM+ 에 등록 되었습니다.

A 라는 COM 에서 B - oDAL - 를 호출하여 사용하고 난 후

Dispose 하고 Nothing 처리를 해 주었는데
구성요소 서비스에서 개체 상태를 살펴보면 A 라는 놈은 서비스 되고 난 후
0 로 되어 있는데 B 라는 놈은 1 로 계속 활성화 상태로
되어 있습니다.

그래서 같은 것을 계속 호출하면 A 라는 놈은 0로 즉시 되는데 B 라는 놈은 숫자가 계속 올라 갑니다.
이런 식이라면 .. 여러 사용자가 계속 호출할 경우 메모리가 오버 되지 않을 까 걱정 입니다

Try
            oDal = CreateObject(gaCert(9))
            fnkgb011nq = oDal.Connect(gaCert)
            If fnkgb011nq <> "" Then Throw New Exception(fnkgb011nq)

            ...................................

            fnkgb011nq = oDal.GetRecordset(sSql, vRtn)
            If fnkgb011nq <> "" Then Throw New Exception(fnkgb011nq)

        Catch oErr As Exception
            fnkgb011nq = My.Application.Info.AssemblyName & "." & "[fnkgb011nq]" & vbCrLf & oErr.Source & vbCrLf & oErr.Message
        Finally
  

            If Not IsNothing(oDAL) Then
                oDAL.Disconnect()
                oDAL.Dispose() ---> 데이타베이스 전담 com
                oDAL = Nothing
            End If

             Dispose()
        End Try

oDAL 을 작성시
--------
Option Strict Off
Option Explicit On

Imports Microsoft.VisualBasic
Imports System.Runtime.InteropServices
Imports System.EnterpriseServices


<System.Runtime.InteropServices.ProgId("PUB_Zaaex.CZaaxt"), _
    JustInTimeActivation(True), EventTrackingEnabled(True), _
    System.EnterpriseServices.TransactionAttribute(System.EnterpriseServices.TransactionOption.NotSupported)> _
Public Class CZaaxt
    Inherits ServicedComponent
-------------------
이렇게 해주었습니다.

-- 그리고 또 하나는 이전 vb 로 작성하고 com+ 에 등록했을때는 해당 클래스에 작성된 메소드들이 다 보였는데
닷넷으로 만들고 난 후에는 메소드들이 안보이는데 어떤 속성을 추가 해야 하는지요?








[최초 등록일: ]
[최종 수정일: 11/17/2005]


비밀번호

댓글 작성자
 



2005-11-16 10시34분
Marshal.ReleaseComObject 메서드를 활용해 보십시오. 그리고, 테스트를 위해 메서드 하나 호출하지 않고, 생성 한 후 마로 release 했을 때와 비교해 가면서 하십시오.

그나저나... oDal 개체가 COM+ 등록된 거 맞나요? COM+ 는 상태 비저장 개체입니다. 지금 "탑" 님이 만드신 것은 무늬만 COM+ 일 뿐, 일반 COM 개체와 별반 차이가 없습니다. 위와 같은 경우에는, 오히려 COM+ 로 올려놓게 되면 문제가 발생할 소지가 다분합니다.

참고로, .NET 에서는 Server 유형으로 COM+ 만드는 것을 권장하지 않습니다. AppDomain 고립의 안정성으로 인해 Library 유형으로 하는 것을 권장합니다.

그리고, 메서드들이 안 보인다고 하셨는데... public 으로 되어 있는 메서드들이 안보인다는 것인가요? 그럼, 문제겠지만... 이외의 private, protected 메서드들이 안 보이는 것은 당연합니다.
kevin25

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5912guest4/25/202316809[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/202311531Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/202311002Async 메서드와 try~catch [1]
5909guest4/22/202312013Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/202311684텅빈 원그리기 [5]
5907민성4/21/202311182안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/202311570Dispatcher 서비스 구현 질문 [1]
5905guest4/20/202312565tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/202312490[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/202311235fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/202312333c#으로 USB 관련 질문 [2]
5901guest4/17/202310642내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/202312723DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/202311367Dictionary와 Linq [4]
5898차가워4/17/202311367CNTK 교육 문의 [1]
5897guest4/17/202311123Socket스레드와 UI thread [4]
5896HAN4/16/202311004c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/202311319Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/202312866[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/202310933오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/202310868C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/202311681안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/202312595C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/202310909C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/202311016C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/202311129안녕하세요 파이썬도 공유 가능 할까요? [1]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...