Microsoft MVP성태의 닷넷 이야기
App Pool idle time 과 WCF 서비스의 비동기 function 호출. [링크 복사], [링크+제목 복사],
조회: 22020
글쓴 사람
YJ
홈페이지
첨부 파일
 

안녕하세요?

한가지 풀기 힘든 것이 있어서 염치 불구하고 이곳에 질문을 올려 봅니다.

현재 제가 만들고 있는 시스템이 WCF 를 이용해서, SSIS Package 를 Running 하고 있습니다.

클라이언트에서는 특정 WCF 서비스를 동기로 호출하고, Back-End 에서는 요청받은 내용을 해석해서,

Package Running 을 비동기 function call로 실행시키고, 클라이언트에 패키지 실행이 성공했다는 메세지를 보냅니다.

이 패키지다 다 돌아가기까지는 30분정도가 걸리는데요.

App Pool 의 idle 타임이 20분인 관계로 20분이 지나니 죽어버리더군요.

즉, App Pool 은 자신이 처리할 Request 가 더이상 남아 있지 않다고 판단되면, 내부에 thread 가 살아 있는지에
관계 없이 죽어버리는 것으로 보입니다.

package 를 exe 나 COM+ 를 통해서 실행 시킬 수도 있지만, 굳이 IIS 상에서 돌리는 이유가 내부적으로 cache에 있는
데이터를 효율적으로 쓰기 위해서, 지금과 같은 형태를 유지하고 싶은데요.

App Pool 에게 아직 작업중인 thread 가 있다는 것을 알려줄 방법이 없을 까요?








[최초 등록일: ]
[최종 수정일: 7/7/2011]


비밀번호

댓글 작성자
 



2011-07-08 07시24분
제가 아는 바로는 작업 중임을 알리는 방법은 없습니다.

그렇긴 하지만, 굳이 idle 20분 제한을 그대로 받아들일 필요가 있을까 싶은데요. idle 타임이 존재하는 이유는, 개발자가 잘못 코딩한 경우에도 가능한 시스템을 안정적으로 유지할 수 있는 역할을 해주는 것이지, 꼭 그것이 강제적으로 받아들여져야 할 요소는 아닙니다.

그러하니, ^^ idle 타임을 1시간으로 늘려도 무방하다고 하겠습니다.

만약 시스템의 특성상 1시간의 idle 조건인 경우 절대 recycle이 발생하지 않아서 시스템이 불안정할 거라고 걱정하실지도 모르겠는데요. 괜찮습니다. ^^ 그에 더해서, "Regular Time Internval" 값이 1740 분으로 설정되어 있기 때문에 29시간 정도마다 한 번씩 recylce 됩니다. ^^
정성태
2011-07-08 10시13분
[YJ] idle 타임은 24시간 정도로 셋팅해서 테스트를 진행했습니다.
하지만, Regular Time Interval 시간이 되었을 때, 실행 중인 thread 가 있을 경우에도
App Pool 이 Recycle 되어 버리면서, thread 의 작업중인 내용이 사라지게 되네요.

다른 방법을 찾아 봐야 겠네요. 답변 감사합니다.
[guest]
2011-07-08 11시14분
그렇다면, 근본적으로 AppPool의 Recycle 간에 "thread의 작업 중인 내용"의 상태가 지속될 수 있는 방법을 사용하는 식으로 우회하는 수 밖에 없겠군요.

생각해 보면, 그런 경우에 WF가 적절한 선택이 되지 않을까 싶은데요. ^^ (아니면, 아예 Recycle 기능을 비활성화 시키거나.)
정성태

1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5765hong12/1/202212660Winform(.Net6) 클라이언트에서 SignalR Core 웹서버에 접속시 인증서 문제 [3]파일 다운로드1
5764요한11/30/202212745c++ 동일한 객체인지 비교 방법문의 [2]
5763고필석11/30/202212004시작하자마자 비정상 종료하는 프로세스에 대한 문제 해결 조언 요청 드립니다. [3]
5762흰털너부리11/30/202211962wpf mvvm ui update 로딩중 표시 [1]
5761민성11/29/202211839죄송하지만 한가지만 더 여쭈어 보겠습니다 [1]
5760민성11/29/202212355안녕하세요 [2]
5759문정환11/28/202212153c# socket 통신할때 빅엔디언으로 바꿔줘야 하나요? [1]
5758라떼11/28/202215293Linux 에서 winform UI 어플리케이션 실행하기 [3]
5757흰털너부리11/25/202213522asp.net core EF AddDbContext,AddDbContextFactory 차이점 알려주세요 [1]
5756흰털너부리11/25/202213739asp.net core web api에서 json 특정 property 무시하는 방법 문의 드립니다. System.Text.Json 사용중입니다. [1]
5755문정환11/24/202213886싱글스레드 프로그램도 컨텍스트 스위칭이 생길 수 있나요? [4]
5754초급11/24/202213992c# 소켓통신 [1]
5753흰털너부리11/24/202212830List와 ObservableCollection을 비교 해서 다른 값 추출 FirstOrDefault 객체 비교 [4]파일 다운로드1
5752푸헐11/15/202211928app.config 에 connectionStrings를 aspnet_regiis로 enctyption [4]
5751차가워11/8/202214497vs2022 preview net7 AOT 콘솔 실행 성능 [7]
5749차가워11/4/202212577전처리 지시문 #if DEBUG 배포시 실행 여부 [1]
5748김기헌11/3/202214096안녕하세요 선생님 싱글톤 패턴을 꼭 이렇게 사용해야 하나요? [6]
5747김기헌11/2/202212892안녕하세요 선생님 네트워크 관련 용어 중 IP 주소가 왜 논리적 주소라고 표현되는 건가요? [2]
5746물냉면이...11/2/202213076서로 다른 클래스에 있는 동일 함수의 일괄 호출 방법에 대해 궁금합니다. [3]
5745흰털너부리11/1/202212580.net core web api 사용 제한에 관한 질문 입니다. [2]
5744차가워10/31/202214802윈폼 Console.WriteLine(); 연산 문의 [1]
5743흰털너부리10/27/202213001reflection, static, override 질문입니다. [1]
5742차가워10/27/202211727하나의 socket에 여러 스레드가 접근 하는 경우 [1]
5741조호상10/27/202212248OpenCVSharp4 구현 가능 문의 [1]
5740혜성10/26/202214519Visual Studio 2022 C# 콘솔 프로그램 기본 코드 변경된 이유는 무엇인가요? [2]
5739슬픈단잠10/25/202213207조언 주신 방법으로 해봤으나, 여전히 어디가 문제인지 파악을 못했습니다. [2]
1  2  3  4  5  6  7  8  [9]  10  11  12  13  14  15  ...