Microsoft MVP성태의 닷넷 이야기
글쓴 사람
guest
홈페이지
첨부 파일
 


Winforms 용 SmartClient 로
개발 중입니다.


win 2003에서 com+, remoting 방식으로 되어 있고요.

db서버와 웹서버가 모두 하나의 머신에 있습니다.

remoting host 는 iis 6.0 을 사용하고 있습니다.
트랜잭션은 [AutoComplete] 로 자동트랜잭션을 사용하고 있습니다.

다른것들은 모두 문제 없이 작동하고 있습니다.
트랜잭션 없는 것은 supported , 있는것은 required 로 설정했고여.

문제는 실행시간이 좀 걸리는 함수 약 10 분정도...
인것을 실행하게 되면...

"삭제된 개체에 액세스 할수 없습니다."
serviced component

라는 메세지가 나오는데...문제가 무엇인지 감을 못잡고 있습니다.
혹시나 해서
MSDTC 의 타임아웃 속성도 0 으로 설정해보고
COM+ 트랜젝션 타이아웃을 0 으로 잡아보기도 했는데
안되네요..

근데 시간이 10분 이내의 것들은 문제없이 실행이 되고
그보다 더 걸리는 것은 타임아웃이 걸리는거 같은데.....


비즈니스 객체의 com+ 속성
    [JustInTimeActivation(true)]
    [EventTrackingEnabled(true)]
    [Transaction(TransactionOption.Required, Isolation = TransactionIsolationLevel.ReadCommitted, Timeout=0)]
    [ClassInterface(ClassInterfaceType.AutoDual)]


데이타베이스 전담 com+ 속성
    [JustInTimeActivation(true)]
    [EventTrackingEnabled(true)]
    [Transaction(TransactionOption.Supported, Isolation = TransactionIsolationLevel.ReadCommitted, Timeout=0)]
    [ClassInterface(ClassInterfaceType.AutoDual)]


어디를 찾아봐야 할지....조언 좀 부탁 드립니다.

== web.config
<?xml version="1.0"?>
<!--
    참고: 이 파일을 직접 편집하는 대신 웹 관리 도구를 사용하면
    사용 중인 응용 프로그램에 대한 설정을 구성할 수 있습니다.
    Visual Studio에서 [웹 사이트]의 [Asp.Net 구성] 옵션을 사용하십시오.
    설정 및 주석에 대한 전체 목록은 일반적으로
    \Windows\Microsoft.Net\Framework\v2.x\Config의
    machine.config.comments에 있습니다.
-->
<configuration>
    <!--리모팅 관련 설정-->
    <system.runtime.remoting>
        <application>
            <channels>
                <channel ref="http"/>
            </channels>
            <service>
                <!-- type = 네임스페이스, 클래스 objectUri=클램스.rem -->
                <wellknown mode="SingleCall" type="Smart.BL.Mba01.MBA100N_nTx,Smart.BL.Mba01" objectUri="MBA100N_nTx.rem"/>
                <wellknown mode="SingleCall" type="Smart.BL.Mba01.MBA100N_Tx,Smart.BL.Mba01" objectUri="MBA100N_Tx.rem"/>

            </service>
            <lifetime leaseTime="30M" sponsorShipTimeout="20M" renewOnCallTime="20M" leaseManagerPollTime="10M"/>
        </application>
        <customErrors mode="Off"/>
    </system.runtime.remoting>
    <appSettings/>
    <connectionStrings/>
    <system.web>
        <authentication mode="Windows"/>
        <globalization requestEncoding="euc-kr" responseEncoding="euc-kr"/>
        <httpRuntime executionTimeout ="1800" shutdownTimeout="1800"/>
    </system.web>
</configuration>



위와 같은 오류 때문에
임시로 해당 비즈니스 객체는
대략 12분정도 걸리지만..
따로 db connection 객체를 만들어서 사용을 해보면 정상 작동합니다.








[최초 등록일: ]
[최종 수정일: 9/29/2007]


비밀번호

댓글 작성자
 



2007-09-29 04시24분
문제를 재현할 수 있는, 최대한 간단한 예제를 올려주시면 확인해 보겠습니다. (기왕이면, "F5" 키만 누르면 재현될 수 있도록 해주시면 더욱 좋겠습니다. ^^)
.NET Remoting 안 써본지 꽤 되었군요. ^^
kevin25
2007-10-01 06시50분
[[손님]] google 검색 중 힌트를 얻어 해결 하였습니다.
시스템 수준에서 트랜잭션 타임아웃이 10분으로 되어 있더군요.

참고사이트)
http://msdn2.microsoft.com/ko-kr/library/System.Transactions.Configuration.MachineSettingsSection.aspx

machine.config 에 아래 태그를 사용하여 변경 하실수 있습니다.

===== (시:분:초)
    <system.transactions>
        <defaultSettings distributedTransactionManagerName="NERPSVR" timeout="00:00:00" />
        <machineSettings maxTimeout="00:00:00" />
    </system.transactions>
====

ps. 모품목 약 800건 자품목 약 35만건 을 mrp 전개하는데 약 15분 정도가 소요되는데...
    느린거겠져?.......
    어케해야 좀더 빠를까요?.....자품목 전개하려고 재귀호출을 하거든요.
    힌트 좀....
[guest]
2007-10-02 06시11분
오... 정말 좋은 정보 감사드립니다. ^^
저도 여지껏 System.Transaction 관련해서 그런 설정이 machine.config 에 있는줄은 몰랐습니다.

말씀하신, 15분 소요는,,, ^^ 별다르게 SQL Query 에 대한 개선의 여지가 없다면 당연한 숫자일 수 있겠습니다. 이런 경우에는 최대한 사용자에게 반응할 수 있는 시간을 높여줘야 할텐데요. 예를 들어, 5페이지 정도의 분량만 먼저 쿼리를 해와서 화면에 불러온 다음에, 이후의 내용은 별도의 쓰레드를 통해서 가져오게 하는 식으로 구현해야 할 것입니다. ^^

kevin25

... 16  17  18  19  20  21  [22]  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5376영귤9/1/20207339nullable 타입간의 비교연산은 그냥 가능한 건가요? [1]
5375영귤8/30/20208832이벤트와 델리게이트의 차이가 궁금합니다. [2]
5374guest8/27/20209862시작하세요! C# 8.0 프로그래밍 책에 오타가 있습니다. [1]
5373agj8/26/20208022System.Single::ToString()함수의 IL코드를 보았는데 ldnull, throw가 전부입니다. 왜 이렇게 짧죠? [2]
5372민성8/24/20208030안녕하세요 WPF 웹브라우저 컨트롤에서 웹브라우저 자체를 엣지로 할 수가 있나요? [2]
5371서현준8/11/20207099Hyper-V 내부 네트워크 환경 중, VM 에서 인터넷 접속 [1]
5370독자8/11/20206114.net createobject 관련 질문입니다.. [4]
5369독자8/10/20206430c# 8.0 프로그래밍 책에 대한 질문 드립니다 [1]
5368guest8/10/20207696시작하세요! C# 8.0 프로그래밍 책에 오타가 있습니다. [1]
5367박순기8/8/20206592디버깅 시 반전되는 부분 글 색상이나 배경색을 변경하는 방법 [3]파일 다운로드1
5366간절함8/7/20207270하나의 솔루션에서, 32비트 프로젝트에서 다른 64비트 프로젝트 참조하는 방법 궁금합니다. [4]
5365영귤8/6/20206516TimeSpan 구할 때 시간대를 바꿔도 같은 값이 나오는 것 같습니다. [1]
5364박순기8/5/20206571visual studio의 menu bar font size 변경방법 문의 [2]파일 다운로드1
5363클락8/1/20207183c# 9.0 출간 준비 중이신가요? [2]
5361하태7/29/20206815안녕하세요! 바이너리데이터 파싱 질문 드리겠습니다!. [2]
5360진우7/28/20207719엑셀에서 발생하는 모든 이벤트를 감지 할수 있는지 궁금합니다. [6]파일 다운로드1
5358홍길동7/22/20206488개체에서 open 속성이나 매서드가 지원 되지 않읍니다.라고 오류창이 뜨는데. [1]
5357손동섭7/22/20206567책 예제코드... [3]
5355neska7/21/20206962안녕하세요 문의 드립니다 [1]
5354민성7/15/20208476안녕하세요 db연결 문자 보안 [2]
5353형성재7/14/20207526Visual Studio Setup Project에서 VC++2010재배포패키지설치 [4]
5352윤식7/10/20207415닷넷코어 빌드 시 runtimeconfig 파일을 없앨 수 있는지.. [4]
5351runr...7/2/20207316C# 에서 C++ dll 병렬 사용 [1]
5350홍성호6/29/20208881C++에서 정의된 구조체(공유메모리)를 C#으로 공유메모리에서 구조체 변환시 에러가 발생 합니다. [1]파일 다운로드1
5349jero...6/24/20206449logon credential provider 관련 문의드립니다. [1]
5348776/19/20206175시작하세요 C# 8.0프로그래밍 책에 대한 질문입니다. [8]
... 16  17  18  19  20  21  [22]  23  24  25  26  27  28  29  30  ...