Microsoft MVP성태의 닷넷 이야기
[답변]: wcf IsOneWay 속성관련 문의 입니다.. [링크 복사], [링크+제목 복사],
조회: 24138
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기

일단, IsOneWay에 대해서 HTTP 요청과 비교해서 설명해보는 것이 좋을 것 같군요.

가령, 다음과 같은 HTTP 요청이 보통의 WCF 요청이라고 보시면 됩니다.

// http://www.codeproject.com/KB/webservices/HttpWebRequest_Response.aspx
private static void start_post()
{
    byte[]  buffer = Encoding.ASCII.GetBytes( "test=postvar&test2=another" );
    HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create("http://127.0.0.1/test.php");
    WebReq.Method = "POST";
    WebReq.ContentType ="application/x-www-form-urlencoded";
    WebReq.ContentLength = buffer.Length;
    Stream PostData = WebReq.GetRequestStream();
    PostData.Write(buffer, 0, buffer.Length);
    PostData.Close();
    HttpWebResponse WebResp = (HttpWebResponse)WebReq.GetResponse();
    Stream Answer = WebResp.GetResponseStream();
    StreamReader _Answer = new StreamReader(Answer);
    Console.WriteLine(_Answer.ReadToEnd());
}

그런데, IsOneWay가 붙은 메서드는 Request가 전달되는 것이 완료되는 것을 확인할 뿐, Response는 확인하지 않는 것입니다. 그래서 다음과 같은 로직이라고 보시면 됩니다.

private static void start_post()
{
    byte[]  buffer = Encoding.ASCII.GetBytes( "test=postvar&test2=another" );
    HttpWebRequest WebReq = (HttpWebRequest)WebRequest.Create("http://127.0.0.1/test.php");
    WebReq.Method = "POST";
    WebReq.ContentType ="application/x-www-form-urlencoded";
    WebReq.ContentLength = buffer.Length;
    Stream PostData = WebReq.GetRequestStream();
    PostData.Write(buffer, 0, buffer.Length);
    PostData.Close();

    WebReq.Close();
}

그럼, 서버 측을 볼까요? 말씀하신 WCF 메서드를 예로 들면,

[OperationContract (IsOneWay = true)]
 void CallTest2 ()
{
    Trace.WriteLine("TEST");
}

위의 메서드가 실행되었다는 것 자체가 이미 Request를 WCF 런타임에서 정상적으로 접수했다는 것을 의미합니다. 따라서 CallTest2가 실행되는 동안에는 이미 클라이언트와의 연결이 끊어진 상태일 수 있습니다.

대강 이해가 되셨죠?




본론으로 넘어가서.

1번 질문의 답변:
일단, string 같은 류의 자원은 별다르게 해제와 관련해서 의미가 없을 것 같고, 게다가 PerCall 서비스라면 연결 관리에 따른 자원해제는 런타임에서 의해서 자동화될 것 같은데... 음... 이 부분에서 딱히 떠오르는 것이 없군요.

2번 질문의 답변:
명백히 다르죠. 말씀하신 dead-lock 요소를 포함해서 콜백으로 받으면 문제가 훨씬 더 복잡해집니다. (물론, 설정만 잘하면 '리턴'이나 '콜백'이나 유사한 효과를 얻겠지만.) 참고로, dead-lock은 설정만 정상적으로 되면 해결이 가능하지만, 지금 겪고 계신 문제에서는 콜백으로 처리할 이유가 전혀 없으므로 생각하지 않는 것이 좋겠습니다.

참고로, 혹시 서버를 Windows 7과 같은 클라이언트용 OS에서 테스트하셨나요? Windos 7과 같은 경우, 동시 접속이 10개 이상 안되는데, 아래의 동영상 화면이 그에 해당합니다.

제니퍼: 7. 성능 관리 퀴즈 첫 번째 문제 (닷넷 개발자 컨퍼런스)
; https://www.sysnet.pe.kr/2/0/875

일단, IsOneWay에서는 잘 되었다는 것을 보면 어떤 이유에서든지 세션 관리에 문제가 있는 것 같긴 한데... 말씀해 주신 현상만으로 어떻게 단정지어서 해결책을 제시하기가 난감하군요. ^^;

별로 답변이 안 된 것 같은데, 혹시 괜찮다면 테스트하신 소스 코드처럼 간단한 유형으로 된 WCF 프로젝트를 저에게 보내주시면 테스트해 보겠습니다.








[최초 등록일: ]
[최종 수정일: 6/26/2021]


비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
894최종문7/14/201019124try/finally 에 관해서 문의 드립니다.
895정성태7/15/201018852    답변글 [답변]: try/finally 에 관해서 문의 드립니다.
896최종문7/15/201020108        답변글 [답변]: [답변]: try/finally 에 관해서 문의 드립니다. [1]
893이병준 donator7/7/201021944Visual Studio 2010 에서의 Build 관련 질문 [1]
889임동찬7/6/201019462아래 887번에 대한 추가 질문
890정성태7/6/201020281    답변글 [답변]: 아래 887번에 대한 추가 질문
891임동찬7/6/201020113        답변글 [추가]: [답변]: 아래 887번에 대한 추가 질문
892정성태7/6/201016854            답변글 [답변]: [추가]: [답변]: 아래 887번에 대한 추가 질문
888김재영7/5/201017024TFS에 반드시! SQL Report랑 SharePoint(or WSS)가 붙어야 합니까? [2]
887임동찬7/2/201018197WCF sendTimeout에 관하여... [1]
886김재영6/16/201018293스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201025857Win32Exception 창 핸들 에러 [1]
883채동민6/10/201018149비동기 DB 쿼리관련 질문
884정성태6/10/201019510    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201019454load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201022193VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201023466wcf 인증 문제 [2]
878채동민4/20/201022377WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201024510Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201020048실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201019078이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201022497WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201023131Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201019362WCF 오류 문의. [1]
863날쌘돌이1/31/201021605ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201019538AppPolId를 알 수 있는 방법이 있는지요? [1]
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...