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


비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5885guest4/11/20233081c#으로 드림위버같은 거 만들어볼려는데요 [6]
5884궁금이4/11/20232970부모 클래스에서 예외 발생시 힙 영역에 할당 ? [2]
5883코딩초짜4/9/2023292910c언어 usleep 에 대해서 요 [2]
5882조은현4/7/20232895선생님 안녕하세요! wpf의 성능 개선에 대해서 질문드려요! [1]파일 다운로드1
5881guest4/6/20233073static method - <에러메시지 Extension method must be defined in a non-generic static class> [4]
5880유비4/4/20232933WPF DataGrid CollectionView, IEditableCollectionView 관련 문의 [1]
5879guest4/4/20233187Async method의 에러 표시 [3]
5878guest4/3/20233237C#으로 CMOS 설정 변경가능한지요? [4]
5875guest4/2/20233659성태님 책을 완독 하고 Static [7]
5874민성4/1/20233048안녕하세요 질문 하나만 드릴깨요~ [1]
5873guest3/31/20233311제어판에서 삭제불가 MS Edge ---> 레지스트리 편집기에서도 안보임 [6]파일 다운로드1
58723/31/20232970web config 파일 확인부탁드려요 [6]
58713/31/20232875web config 파일 수정이요 [2]파일 다운로드1
5870guest3/30/20233353.NET Core SDK 삭제 시 주의 사항 [4]파일 다운로드1
5869guest3/30/20233568Dictionary의 Update 그리고 Foreach [7]
5868guest3/29/20233040Speech Recognition과 Form1 그리고 정확도 [4]파일 다운로드1
5866월급쟁이3/28/20233143cmake 크로스 컴파일 관련하여 질문이 있습니다 [1]
5865guest3/28/20233014Github Copilot과 코딩실력 향상? [1]
5864guest3/27/20233444System.NullReferenceException - 개체참조가 개체의 인스턴스... [6]파일 다운로드1
5863guest3/24/20233560이벤트 핸들러 사라짐 현상 - Button [4]
5862guest3/21/20233649세계최초 hts와 싱글스레드 [8]
5861다크파이썬3/21/20233811WPF를 사용하려고 하려고 도서 문의합니다. [2]
5860guest3/21/20233113인텔코어 i5 CPU와 스레드 [4]
5859guest3/21/20232919개발 일지 어떻게 관리하시나요? 이런 프로그램 없나요? [3]
5858김태원3/18/20233036안녕하세요! [5]
5857guest3/17/20233102귀도 반 로썸을 보고 [4]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...