Microsoft MVP성태의 닷넷 이야기
[답변]: wcf IsOneWay 속성관련 문의 입니다.. [링크 복사], [링크+제목 복사]
조회: 15720
글쓴 사람
정성태 (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]


비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1238(non...3/13/201411923(글쓴이의 요청으로 삭제합니다.) [2]
1237(non...3/11/201412056(글쓴이의 요청으로 삭제합니다.) [2]
1236(non...3/11/201412946(글쓴이의 요청으로 삭제합니다.) [2]
1235(non...3/10/201412069(글쓴이의 요청으로 삭제합니다.) [2]
1234(non...3/10/201414097(글쓴이의 요청으로 삭제합니다.) [3]
1233(non...3/9/201412206(글쓴이의 요청으로 삭제합니다.) [4]
1232(non...3/8/201411308(글쓴이의 요청으로 삭제합니다.) [2]
1231(non...3/7/201412601(글쓴이의 요청으로 삭제합니다.) [9]
1230POCO3/7/201412951쓰레드 안에서 DependencyProperty get, set시 또 다른 스레드 오류.. [1]
1229(non...3/6/201412675(글쓴이의 요청으로 삭제합니다.) [11]
1228POCO3/6/201411195안녕하세요. 질문이 있습니다. [1]
1226김형진3/4/201419780안녕하세요 windows azure에 관해 질문했던 사람입니다. [2]
1224(non...3/3/201415896(글쓴이의 요청으로 삭제합니다.) [11]
1223sadf...3/3/201411499아래 질문에 답변 감사드립니다. 한가지 더 궁금한점이 있어 질문드립니다. [1]
1222(non...3/2/201412336(글쓴이의 요청으로 삭제합니다.) [4]
1221(non...3/1/201412389(글쓴이의 요청으로 삭제합니다.) [2]
1220Until2/28/201410915질문드립니다. [1]
1219이성환2/28/201410593string.Join()과 Enumerable.Aggregate()의 차이가 궁금합니다. [2]파일 다운로드1
1218김형진2/25/201412047안녕하세요. window azure에 대해서 질문이 있어서 문의 드립니다 [4]
1217(non...2/23/201412509(글쓴이의 요청으로 삭제합니다.) [1]
1215아리수2/20/201416031C# 공부하면서 WPF에 대한 질문. [2]
1214조광훈2/20/201414268IIS8 응용프로그램 풀 관련 질문 드립니다. [2]파일 다운로드1
1213김태훈2/17/201411162가상화 프로그램 질문입니다. [1]파일 다운로드1
1212조광훈2/13/201410320ISAPI 필터에서 커스텀 헤더 정보 추가 [1]파일 다운로드1
1211조광훈2/12/201413748isapi 필터 로드 오류 [2]
1208박지호2/9/201417084[오타] 시작하세요 C# 프로그래밍 p.267 ~ 350 [1]
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...