Microsoft MVP성태의 닷넷 이야기
비동기 DB 쿼리관련 질문 [링크 복사], [링크+제목 복사],
조회: 10736
글쓴 사람
채동민 (dm72.chae at samsung.com)
홈페이지
첨부 파일
 

늘 빠른 답변에 감사드립니다.

현재 사이트 사정상 클라이언트측 inactivity timeout을 10초로 변경해 두었는데 그런 상태에서 수백만건의 데이터를 쿼리할 경우에
(Quotas 상의 제약을 지켜도) 실제DB에서 데이터를 가져오는 동안 블러킹 되어서 인지 WCF채널이 faulted(inactivty timeout때문) 상태가
되는 듯(?) 합니다.

그래서 서비스 쪽에서 아래와 같이 비동기적으로 처리하도록 해보았는데 여전히 채널에서 문제를 발생시키더군요.
아시다시피 하나의 서비스 함수내 에서 결과를 리턴 해주고자 이벤트 방식보다는 폴링방식으로 시도해 보았는데 여전히 채널이 망가집니다.

sleep(0)를 주는 대신에 WCF 채널이 비활성되지 않도록 서비스쪽에서 취할수 있는 다른 방법이 없을까요?
제어권만 놓아주면 WCF 채널이 유지될 것으로 추측해 보았는데 그건 아닌듯하군요.

DAC
{
   List<AlarmMessageHistoryT> logs = new List<AlarmMessageHistoryT>();
   SqlDataReader reader = agent.asyncExecuteReader(query);
   while (reader.Read())
   {
      AlarmMessageHistoryT item = new AlarmMessageHistoryT();
      fromReader(item, reader);
      logs.Add(item);
   }
   return logs;
}


public SqlDataReader asyncExecuteReader(string strQuery)
{
  CreateConnection();
  SqlDataReader reader = null;
  try
  {
    SqlCommand cmd = new SqlCommand(strQuery, _connection);
    ...    
    _connection.Open();
    IAsyncResult ar = cmd.BeginExecuteReader(CommandBehavior.CloseConnection);
    while (!ar.IsCompleted)
    {
      System.Threading.Thread.Sleep(0);
      //System.Windows.Forms.Application.DoEvents();
    }
    reader = cmd.EndExecuteReader(ar);
    ...
  }
  catch (Exception ex)
  {
  }
  finally
  {
    CloseConnection();
  }
  return reader;
}








[최초 등록일: ]
[최종 수정일: 6/10/2010]


비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5648주니어개...4/13/20224051컴파일된 코드를 원시코드로 바꾸려면 어떻게해야하나요? [1]파일 다운로드1
5647장성욱4/7/20224093코어지정 CPU사용률 관련 질문 [1]
5646서형주4/6/20224128List에 여러개의 class 객체를 만들어 넣을때, 객체의 method들도 같이 생성되어 메모리를 차지하나요? [1]
5645김인태4/6/20223782윈도우즈 서버의 AD 계정 생성 조건이 있을까요? [1]
5644ㅇㅇ4/6/20224536c# 프로그램을 이용하여 리눅스상에 파일 생성이 가능한가요? [1]
5643유필재4/5/20224387TCP클라이언트 연결 및 통신관련하여 문의드려요 [1]
5642차가워4/4/20224632UdpClient 패킷 수신 문의 [4]
5641장성욱4/4/20224994코어 할당 및 cpu 부하테스트 질문 [7]
5640icoo...4/4/20224580웹가든에서 메모리 동적 업데이트 방법 [1]
5639차가워4/4/20224469c++ 서버 c# 클라이언트 호환 문의 [1]
5638초급4/3/20224761c# sql server 연동 [1]
5637따봉이4/1/20225048Winform Form Load 후 자동 캡쳐관련 [1]파일 다운로드1
5636김철순3/31/20225021WPF에서 Richtext의 View 문의 [5]
5635guest3/30/20225008안정적인 pinning이 가능하네요. [3]파일 다운로드1
5633꿀주세요3/30/20224690선생님 마우스 클릭이벤트 질문이 있습니다. [4]
5632김현수3/30/20224963Remote Desktop으로 접속시 WPF UI 가 다시 그려지는 이벤트를 막을 수 없을까요? [3]
5631김기헌3/24/20224662WPF 컨트롤의 그래픽 처리관련 질문드립니다 [2]파일 다운로드1
5630장성욱3/24/20224481로깅관련 질문입니다. [2]
5629감사합니...3/23/20224729함수에서 예외가 발생하면 try ~ catch처리기를 찾을 때 까지 상위 함수로 계속 올라가나요? [2]
5628홍길동3/23/20225365질문드립니다. [2]파일 다운로드1
5626연준혁3/21/20224594안녕하세요. [3]
5625jaew...3/18/20225492c# 8.0 도서를 구입한 사람입니다. [1]
5624초보자3/17/20224493람다 캡처 관련 문의 [2]
5623한예지 donator3/15/20224820인터프리터 원리가 궁금합니다. [4]
5622김민아3/8/20224816const와 readonly의 명확한 차이가 이게 맞나요? [2]
5621장성욱3/8/20224622c# 로그 관련 질문 [1]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...