Microsoft MVP성태의 닷넷 이야기
[답변]: 비동기 DB 쿼리관련 질문 [링크 복사], [링크+제목 복사],
조회: 17598
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

제가 기억하기로는 위에서 적은 DAC 코드가 실행되는 곳이 WCF 서버 측이죠?
그리고, 위의 DAC 코드가 실행되는 WCF메서드를 호출하는 곳이 별도로 클라이언트이고.

그런데, 클라이언트에서 그 WCF 메서드를 실행하면 InactivityTimeout 때문에 WCF 채널이 faulted 상태로 빠지는 것이죠?

위의 코드라면, 그렇게 되는 것이 맞습니다.
왜냐하면 위의 DAC 코드에서 사용한 BeginExecuteReader는 비동기 함수이긴 하지만, 그 이후에 while 문을 통해서 쓰레드를 여전히 점유하고 있기 때문에, WCF 메서드를 부른 클라이언트 측 역시 계속 블로킹 상태에 놓이게 됩니다.

while 문으로 받아서는 안되고 콜백함수를 통해서 처리를 하셔야 하는데요. 물론 그렇게 하면 클라이언트 측은 WCF 메서드를 부르고는 결과를 받지도 못하고 쓰레드가 진행되기 때문에 또한 문제가 발생합니다.

제 생각에는, 이런 경우 문제를 해결하기 위해서는 어쨌든 클라이언트 쓰레드를 최대한 자유롭게 해주어야 합니다.
이런식으로 우회해야 할 것 같습니다.

=== client ====
int cookie = wcf_channel.DoMethod(); // WCF 메서드를 호출

=== server ====
int DoMethod()
{
int random_cookie = ....; // 메서드 호출 구분을 위한 고유값을 구해놓고. (또는 Guid 로 한다든가.)
cmd.BeginExecuteReader(...); // 비동기 호출을 하고.
return cookie; // 곧바로 cookie 값만을 반환해서 클라이언트 측 쓰레드를 자유롭게 놓아주고.
}

void BeginExecuteReader_Callback_Result() // BeginExecuteReader 에 대한 비동기 콜백함수가 실행되고.
{
... // DB 쿼리 조회값을 구하고.
channel_Callback(cookie, logs); // 클라이언트 측에 WCF 콜백 메서드를 호출
}

==== client ====

void channel_Callback(int cookie, List logs)
{
// 이때, 최초 wcf_channel.DoMethod(); 호출 결과에 대한 값을 처리.
}



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







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


비밀번호

댓글 작성자
 




... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
3611나그네9/30/201517797안녕하세요 답글을 이제 보았습니다. [3]
3608기차니9/21/201518231컬럼이 많은 데이터그리드에서 정렬 할 때 속도가 느립니다. [3]
3609기차니9/22/201517881    답변글 [답변]: 컬럼이 많은 데이터그리드에서 정렬 할 때 속도가 느립니다. [1]파일 다운로드1
3610기차니9/23/201520089        답변글 [답변]: [답변]: 컬럼이 많은 데이터그리드에서 정렬 할 때 속도가 느립니다. [5]파일 다운로드1
3606guest9/20/201518211확장 클래스 네이밍 규칙은 어떻게 하시나요? [1]
3605spow...9/18/201517368익명형식을 다른 클래스의 인스턴스로 전달하고 싶습니다. [1]
3604popo9/11/201519250[C#] Singleton 을 사용하면서 궁금한점이 있어 질문 남깁니다. [2]
3603강준9/11/201517651xamarin 을 시작하려고 하는데 혹시 도움이 될만한 사이트나 정보 있으면 공유해 주세요~~ [1]
3602Mink...9/9/201518842aspx > 다른 확장자로 변경 후 디버깅 때문에 질문 드려 봅니다. [10]
3601edain9/8/201519267캐스팅...에 관해 궁금합니다. [5]
3600guest9/7/201522639C# 버전의 정의는 어떻게 구분하나요? [2]
3599김태훈9/4/201519669안녕하세요. C언어를 배우려고 하는 문과생입니다. [1]
3598미니8/29/2015221236.0은 전체소스? [1]
3597손성수8/28/201519343시작하세요 ! c# 프로그래밍 이책으로 배우고 있는데요 [2]
3596지나가는...8/26/201518179크로스플랫폼 [1]
3594guest8/25/201517658요즘 Windonws Form 기반 N Tier 어떻게 구성하나요?? [1]
3593개발자8/18/201521921현 시점에서 VS 버전은 뭐가 좋을까요? [8]
3592나그네8/15/201520260안녕하세요 질문이 있어서... [4]
3589spow...8/11/201521339Nancy + Razor 사용시 cshtml의 IntelliSense 및 참조 오류 [3]
3590spow...8/12/201519712    답변글 [질문]: (첨부 추가) [1]파일 다운로드1
3588재현8/8/201526157안녕하세요. C# 6.0 책을 보는 중에 의문이 생겨 질문드립니다. [4]
3587주문중8/4/201526430신간 출간 [7]
3586꿈꾸는개...7/29/201520514자바스크립트 checkbox 관련하여 ie10에서 호완이 안되는 부분이 있어 질문드립니다 [1]
3585유동근7/21/201519882TTS오류 [1]파일 다운로드1
3583노영우7/20/201519446iisnode 를 클래식 파이프라인 모드에서 호스팅하기 [2]
3582황희성7/17/201521701동영상 캡쳐에 관련해서 궁금하것이 있습니다. [6]파일 다운로드1
... 46  47  48  49  [50]  51  52  53  54  55  56  57  58  59  60  ...