Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

wsDualHttpBinding + Windows Server 2003인 경우 발생하는 오류

WSDualHttpBinding 설정의 WCF 서비스를 윈도우 서버 2003 x86 IIS 6.0에서 호스팅하는 경우 ServerTooBusyException, CommunicationObjectFaultedException이 발생할 수 있습니다.

테스트를 위해 웹 프로젝트를 하나 만들고 간단하게 svc 서비스를 추가합니다.

// 인터페이스 정의
using System.ServiceModel;

namespace WebApplication1
{
    [ServiceContract(Namespace = "http://www.wcftest.com/", SessionMode = SessionMode.Required, 
        CallbackContract = typeof(ITestWcfCallback))]
    public interface ITestWcf
    {
        [OperationContract]
        void CheckMethod();

        [OperationContract]
        void CheckMethod2();
    }

    public interface ITestWcfCallback
    {
        [OperationContract(IsOneWay = true)]
        void Reply();
    }
}

// WCF 구현 클래스 정의
using System.ServiceModel;

namespace WebApplication1
{
    [ServiceBehavior(InstanceContextMode = InstanceContextMode.PerSession)]
    public class TestWcf : ITestWcfCallback
    {
        public void CheckMethod()
        {
        }

        public void CheckMethod2()
        {
        }
    }
}

마지막으로 test.aspx 웹 페이지를 만들어 WCF 호출을 해봅니다.

using System;
using System.ServiceModel;

namespace WebApplication1
{
    public partial class test : System.Web.UI.Page
    {
        public class TestCallback : ITestWcfCallback
        {
            public void Reply()
            {
            }
        }

        protected void Page_Load(object sender, EventArgs e)
        {
            string hostName = Request.Url.Host.ToLowerInvariant();
            int hostPort = Request.Url.Port;

            TestCallback tcb = new TestCallback();
            InstanceContext ctx = new InstanceContext(tcb);

            // http://localhost:.../WCFs/TestWcf.svc/addrWsDualHttpBinding
            string wsDualBindingAddress = string.Format("http://{0}:{1}/TestWcf.svc/addrWsDualHttpBinding",
                hostName, hostPort);

            WSDualHttpBinding wsDualHttpBinding = new WSDualHttpBinding();
            wsDualHttpBinding.Security.Mode = WSDualHttpSecurityMode.None;

            DuplexChannelFactory<ITestWcf> factory =
                new DuplexChannelFactory<ITestWcf>(ctx, wsDualHttpBinding,
                new EndpointAddress(wsDualBindingAddress));
            {
                ITestWcf proxy = factory.CreateChannel();

                proxy.CheckMethod();
                proxy.CheckMethod2();

                IClientChannel comm = proxy as IClientChannel;

                try
                {
                    comm.Close();
                }
                catch
                {
                    comm.Abort();
                    throw;
                }
                finally
                {
                    try
                    {
                        factory.Close();
                    }
                    catch
                    {
                        factory.Abort();
                    }
                }
            }
        }
    }
}

이렇게 만든 웹 사이트를 Windows Server 2003 x86 환경과 그 외의 테스트 서버 환경에 각각 배포해 봅니다. (.NET 3.5든, .NET 4.0이든 상관없습니다.)

준비가 되었으면 test.aspx 웹 페이지를 방문해서 테스트를 해보면 되는데요. 이상하게도 윈도우 서버 2003 x86에서만 다음과 같이 오류가 발생했습니다.

The communication object, System.ServiceModel.Channels.ServiceChannel, cannot be used for communication because it is in the Faulted state.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.ServiceModel.CommunicationObjectFaultedException: The communication object, System.ServiceModel.Channels.ServiceChannel, cannot be used for communication because it is in the Faulted state.

Source Error:
An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:
[CommunicationObjectFaultedException: The communication object, System.ServiceModel.Channels.ServiceChannel, cannot be used for communication because it is in the Faulted state.]
System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg) +7600991
System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type) +275
WebApplication1.ITestWcf.CheckMethod2() +0
WebApplication1.test.Page_Load(Object sender, EventArgs e) in d:\...\WebApplication1\test.aspx.cs:37
System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +35
System.Web.UI.Control.OnLoad(EventArgs e) +99
System.Web.UI.Control.LoadRecursive() +50
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +627
--------------------------------------------------------------------------------
Version Information: Microsoft .NET Framework Version:2.0.50727.3643; ASP.NET Version:2.0.50727.3634


또는 다음과 같은 오류가 발생하는 경우도 있습니다. (Dual 채널에 대한 callback 인터페이스를 구현하지 않았을 때!)

The remote endpoint no longer recognizes this sequence. This is most likely due to an abort on the remote endpoint. The value of wsrm:Identifier is not a known Sequence identifier. The reliable session was faulted.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.ServiceModel.CommunicationException: The remote endpoint no longer recognizes this sequence. This is most likely due to an abort on the remote endpoint. The value of wsrm:Identifier is not a known Sequence identifier. The reliable session was faulted.

Source Error:
An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:
[CommunicationException: The remote endpoint no longer recognizes this sequence. This is most likely due to an abort on the remote endpoint. The value of wsrm:Identifier is not a known Sequence identifier. The reliable session was faulted.]
System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg) +221
System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type) +883
WebApplication1.ITestWcf.CheckMethod2() +0
WebApplication1.test.Page_Load(Object sender, EventArgs e) in d:\...\WebSiteTest\test.aspx.cs:365
System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +43
System.Web.UI.Control.OnLoad(EventArgs e) +91
System.Web.UI.Control.LoadRecursive() +74
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +2645
--------------------------------------------------------------------------------
Version Information: Microsoft .NET Framework Version:2.0.50727.3643; ASP.NET Version:2.0.50727.3634


재미있는 점은, 위의 오류가 초기에 발생하다가 어느 순간부터는 정상적으로 서비스를 한다는 것입니다. 그런데 ^^ 더욱 재미있는 점은 가끔 초기 호출이 많이 몰렸을 때 정상 서비스 상태로 진입하지 못하고 다음과 같은 예외로 넘어가는 경우도 있었는데요.

The request to create a reliable session has been refused by the RM Destination. Server 'http://testsrv:10800/TestWcf.svc/addrWsDualHttpBinding' is too busy to process this request. Try again later. The channel could not be opened.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.ServiceModel.ServerTooBusyException: The request to create a reliable session has been refused by the RM Destination. Server 'http://testsrv:10800/TestWcf.svc/addrWsDualHttpBinding' is too busy to process this request. Try again later. The channel could not be opened.

Source Error:
An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:
[ServerTooBusyException: The request to create a reliable session has been refused by the RM Destination. Server 'http://testsrv:10800/TestWcf.svc/addrWsDualHttpBinding' is too busy to process this request. Try again later. The channel could not be opened.]
System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg) +222
System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type) +883
WebApplication1.ITestWcf.CheckMethod2() +0
WebApplication1.test.Page_Load(Object sender, EventArgs e) in d:\...\WebApplication1\test.aspx.cs:25
System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +43
System.Web.UI.Control.OnLoad(EventArgs e) +91
System.Web.UI.Control.LoadRecursive() +74
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +2645
--------------------------------------------------------------------------------
Version Information: Microsoft .NET Framework Version:2.0.50727.3643; ASP.NET Version:2.0.50727.3634


일단 한번 ServerTooBusyException 예외가 발생하면 그 이후로는 iisreset을 하기 전까지 WCF 서비스가 완전히 먹통이 되었습니다.

물론, 지금까지 설명한 모든 현상들이 윈도우 서버 2003 x64나 2008 R2 등의 환경에서는 동일한 소스에 동일한 AppPool설정임에도 전혀 발생하지 않았습니다. (그 외 다른 서버는 테스트 하지 않았습니다.) 심지어 같은 2003 서버내에서도 wsDualHttpBinding WCF 서비스를 콘솔 응용 프로그램에서 호스팅하는 경우 정상적으로 동작을 했습니다.

게다가, 위의 소스 코드에 보면 CheckMethod, CheckMethod2 2개의 호출을 부르고 있는데요. 매번 오류가 발생하는 곳은 CheckMethod2였는데, 이 메소드를 없애고 CheckMethod 한개만 부르면 이런 오류가 다시 발생하지 않았습니다.

정리해 보면, 이번 글의 해결책은 없습니다. 제가 가지고 있는 2003 x86 테스트 서버의 환경적인 문제일 수도 있고... 기타 여러 환경적인 요인을 배제할 수 없으므로 단순히 이런 현상을 겪었음을 설명하는 것입니다. (그래도 왠지 ^^ wsDualHttpBinding WCF 서비스를 해야 한다면 2008 R2에서 하고 싶군요.)




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







[최초 등록일: ]
[최종 수정일: 1/26/2014]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11024정성태8/12/201621634오류 유형: 350. "nProtect GameMon" 실행 중에는 Visual Studio 디버깅이 안됩니다! [1]
11023정성태8/10/201623071개발 환경 구성: 293. Azure 구독 후 PaaS 서비스 만들어 보기
11022정성태8/10/201623750개발 환경 구성: 292. Azure Cloud Service 배포시 사용자 정의 작업을 추가하는 방법
11021정성태8/10/201620862오류 유형: 349. System.Runtime.Remoting.RemotingException - Type '..., ..., Version=..., Culture=neutral, PublicKeyToken=null' is not registered for activation [2]
11020정성태8/10/201623569VC++: 98. 원본과 대상 버퍼가 같은 경우 memcpy, wmemcpy 주의점
11019정성태8/10/201640217기타: 60. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 (2쇄 정오표)
11018정성태8/9/201624716.NET Framework: 600. 단일 메서드 내에서의 할당으로 알아보는 자바와 닷넷의 GC 차이점 [1]
11017정성태8/9/201626781웹: 33. HTTP 쿠키에 한글 값을 설정하는 방법
11016정성태8/7/201623943개발 환경 구성: 291. Windows Server Containers 소개
11015정성태8/7/201622226오류 유형: 348. Windows Server 2016 TP5에서 Windows Containers의 docker run 실행 시 encountered an error during Start failed in Win32
11014정성태8/6/201623029오류 유형: 347. Hyper-V Virtual Machine Management service Account does not have permission to open attachment
11013정성태8/6/201633742개발 환경 구성: 290. Windows 10에서 경험해 보는 Windows Containers와 docker [4]
11012정성태8/6/201623797오류 유형: 346. Windows 10에서 Windows Containers의 docker run 실행 시 encountered an error during CreateContainer failed in Win32 발생
11011정성태8/6/201625423기타: 59. outlook.live.com 메일 서비스의 아웃룩 POP3 설정하는 방법
11010정성태8/6/201622832기타: 58. Outlook에 설정한 SMTP/POP3(예:천리안 메일) 계정 암호를 잊어버린 경우
11009정성태8/3/201628016개발 환경 구성: 289. 2016-08-02부터 시작된 윈도우 10 1주년 업데이트에서 Bash Shell 사용 [8]
11008정성태8/1/201621796오류 유형: 345. 2의 30승 이상의 원소를 갖는 경우 버그가 발생하는 이진 검색(Binary Search) 코드
11007정성태8/1/201623541오류 유형: 344. RDP ActiveX 컨트롤로 특정 PC에 연결할 수 없을 때, 오류 상황을 해결하기 위한 팁파일 다운로드1
11006정성태7/22/201626544개발 환경 구성: 288. SSL 인증서를 Azure Cloud Service에 적용하는 방법
11005정성태7/22/201625194개발 환경 구성: 287. Let's Encrypt 인증서 업데이트 주기: 90일
11004정성태7/22/201620017오류 유형: 343. Invalid service definition or service configuration. Please see the Error List for more details.
11003정성태7/20/201627277VS.NET IDE: 110. Visual Studio 2015에서 .NET Core 응용 프로그램 개발 [1]
11002정성태7/20/201620756개발 환경 구성: 286. Microsoft Azure 서비스의 구독은 반드시 IE로!
11001정성태7/19/201631760.NET Framework: 599. .NET Core/SDK 설치 및 기본 사용법 [6]
11000정성태7/16/201620469오류 유형: 342. Microsoft Visual Studio 2010 Tools for Office Runtime (x86 and x64) 설치 시 오류
10999정성태7/16/201622014오류 유형: 341. .NET Framework 4.5.2가 설치 안 되는 경우
... 106  107  108  109  110  111  112  113  114  115  [116]  117  118  119  120  ...