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


비밀번호

댓글 작성자
 




... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
5044엿장수8/20/20188258graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
5043hori...8/20/20187878Expression에 대한 책의 예제 관련하여 질문드립니다. [1]
5042황윤하8/20/20189600모드버스 TCP 관련 질문 [3]
5041david8/18/20189240.NET WebAPI 에서 Response 지연되는 이유 [3]
5040농상8/14/20188712정규표현식에 대해서 [3]
5039유영태8/14/201810266비동기 소켓사용후 해당 스레드가 남아있을때 처리 방법 [4]파일 다운로드1
5038이정석8/9/20188415서버파일 로컬파일 비교 [2]
5037jjh8/8/201811806c# 으로 화면캡쳐해서 동영상으로 만드는앱을 만들고싶습니다 [6]
5036볼딱지8/8/20189607C# programming 개발 관련 질문이 있습니다. [1]
5035궁금합니...8/8/201810291C# 버전 고민 어떤 책을 사야하나요? [1]
5034신동열8/8/20188711덤프 파일 분석 관련해서 문의 드려요. [1]
5033최규성8/7/201810803C# WinForm, Oracle 9i 로 프로그래밍시 ODP.NET, 배포 설정 방법 질문입니다. [6]
5032이정석8/6/201812617C# 으로 만들 dll 등록 [7]
5031J.S.8/6/20188262System.Array class의 구조에 대한 질문 [1]
5030농상8/4/20188802람다 식을 이용한 메서드 정의 확대를 공부하고 있습니다. [2]
5029Soul...8/3/20188309C# ActiveX 컨트롤 질문드립니다. [4]
5028도토리8/1/20188854혹시 회사에서 TFS 구축시 SQL-Server 라이선스 정책 아시는분 계신지요? [2]
5027농상7/31/20189660Freachable Queue의 발음을 표기하면 어떨까요? [2]
5026농상7/31/201812148소멸자의 이름에 대해서 [2]
5025김기철7/30/20189599selenium 질문좀 드릴개요 [3]
5024농상7/29/20188869패턴 매칭 when에 대해서 질문있습니다. [2]
5023농상7/28/201811857패턴매칭에 대해서 질문 있습니다. [1]
5022농상7/28/20188849튜플에 대해서 건의가 있습니다. [1]
5021농상7/27/20188343예외필터에 대해서 질문이요 [4]
5020농상7/27/201811238null 조건 연산자 예제에서 잠깐 혼동이 일어났습니다. [1]
5019농상7/26/201813548오버플로우와 언더플로우 [2]
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...