Microsoft MVP성태의 닷넷 이야기
오류 유형: 13. WSE 3.0 서비스 관련 WSE101 오류 / Destination Unreachable [링크 복사], [링크+제목 복사],
조회: 21743
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

WSE 3.0 을 로컬에서만 테스트 하다가, 머신을 분리하게 되면 겪게 되는 현상입니다. (이 현상은 로컬에서 조차도 발생하는 문제입니다.)

저도 아직 이 부분에 대한 뚜렷한 이유는 설명해드릴 수 없습니다. 웹에서도 해당 현상에 대해서 적절한 설명을 찾을 수가 없었는데, 혹시나 아시는 분 계시면 ^^ 댓글 좀 부탁드립니다.

따라서, 이 부분은 WSE 3.0 으로 프로그램하시면 반드시 지켜주셔야 하는데요.

서버 대기 주소와 클라이언트의 접속 주소를 "동일"하게 유지하라.

입니다. 감이 안 오실텐데요. ^^ 코드로 살펴보도록 하겠습니다.

우선, 서버측에서는 서비스를 대기하기 위해서 다음과 같이 작성하게 됩니다.

 Uri listenAddress = new Uri("soap.tcp://localhost/HelloService");
 SoapReceivers.Add(new EndpointReference(listenAddress), typeof(HelloService));

위와 같이 서비스를 작성했다면 원격 컴퓨터에 있는 클라이언트에서는 다음과 같이 서비스를 접근하려 할텐데요.

HelloService service = new HelloService();
service.Url = "soap.tcp://192.168.1.100/HelloService";

서버는 "localhost" 로 대기하고, 클라이언트는 "192.168.1.100" 으로 접근하고 있는데요. 바로 이와 같이 접속 주소가 다르게 되면 오류가 발생하게 됩니다. 따라서 이런 경우에는 서버측의 대기 주소를 다음과 같은 식으로 수정해 주셔야 합니다.

 Uri listenAddress = new Uri("soap.tcp://192.168.1.100/HelloService");

심지어, 같은 로컬 컴퓨터에서조차도 "localhost" 로 대기하고, "127.0.0.1" 로 접속해도 오류가 발생합니다.



다음의 2가지 오류 메시지는 위에서 설명한 것처럼 주소가 달라질때 발생하는 것들입니다.

[오류 메시지 1]

Unhandled Exception: Microsoft.Web.Services3.AsynchronousOperationException: 
WSE101: An asynchronous operation raised an exception. 
	---> System.Net.Sockets.SocketException: 
			No connection could be made because the target machine actively refused it

Server stack trace:
   at Microsoft.Web.Services3.Messaging.SoapTcpConnection.Connect()
   at Microsoft.Web.Services3.Messaging.SoapTcpConnection..ctor(Uri remoteEndpoint, SoapTcpTransportOptions options, ISoapFormatter formatter)
   at Microsoft.Web.Services3.Messaging.SoapTcpTransport.CreateConnection(Uri transportAddress)
   at Microsoft.Web.Services3.Messaging.SoapTcpTransport.GetConnection(Uri destination)
   at Microsoft.Web.Services3.Messaging.SoapTcpOutputChannel.Send(SoapEnvelope message)
   at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
   at System.Runtime.Remoting.Messaging.StackBuilderSink.PrivateProcessMessage(RuntimeMethodHandle md, Object[] args, Object server, Int32 methodPtr, Boolean fExecuteInContext, Object[]& outArgs)
   at System.Runtime.Remoting.Messaging.StackBuilderSink.AsyncProcessMessage(IMessage msg, IMessageSink replySink)

Exception rethrown at [0]:
   at System.Runtime.Remoting.Proxies.RealProxy.EndInvokeHelper(Message reqMsg,Boolean bProxyCase)
   at System.Runtime.Remoting.Proxies.RemotingProxy.Invoke(Object NotUsed, MessageData& msgData)
   at Microsoft.Web.Services3.Messaging.SoapOutputChannel.SendDelegate.EndInvoke(IAsyncResult result)
   at Microsoft.Web.Services3.Messaging.SoapOutputChannel.EndSend(IAsyncResult result)
   at Microsoft.Web.Services3.WebServicesClientAsyncResult.OnSendComplete(IAsyncResult result)
   --- End of inner exception stack trace ---
   at Microsoft.Web.Services3.AsyncResult.End(IAsyncResult result)
   at Microsoft.Web.Services3.Xml.SoapEnvelopeReaderWrapper..ctor(SoapClientMessage message, String messageContentType)
   at Microsoft.Web.Services3.WebServicesClientProtocol.GetReaderForMessage(SoapClientMessage message, Int32 bufferSize)
   at System.Web.Services.Protocols.SoapHttpClientProtocol.ReadResponse(SoapClientMessage message, WebResponse response, Stream responseStream, Boolean asyncCall)
   at System.Web.Services.Protocols.SoapHttpClientProtocol.Invoke(String methodName, Object[] parameters)
   at HelloService.HelloWorld() in D:\temp\ConsoleHostService\WSE30Consumer\HelloService.cs:line 43
   at WSE30Consumer.Program.Main(String[] args) in D:\temp\ConsoleHostService\WSE30Consumer\Program.cs:line 15

[오류 메시지 2]

Unhandled Exception: System.Web.Services.Protocols.SoapHeaderException: Destination Unreachable
   at System.Web.Services.Protocols.SoapHttpClientProtocol.ReadResponse(SoapClientMessage message, WebResponse response, Stream responseStream, Boolean asyncCall)
   at System.Web.Services.Protocols.SoapHttpClientProtocol.Invoke(String methodName, Object[] parameters)
   at HelloService.HelloWorld() in D:\temp\ConsoleHostService\WSE30Consumer\HelloService.cs:line 43
   at WSE30Consumer.Program.Main(String[] args) in D:\temp\ConsoleHostService\WSE30Consumer\Program.cs:line 22



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







[최초 등록일: ]
[최종 수정일: 10/18/2006]

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

비밀번호

댓글 작성자
 




... [61]  62  63  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12415정성태11/18/202017462.NET Framework: 971. UnmanagedCallersOnly 특성과 DNNE 사용파일 다운로드1
12414정성태11/18/202019656VC++: 138. x64 빌드에서 extern "C"가 아닌 경우 ___cdecl name mangling 적용 [4]파일 다운로드1
12413정성태11/17/202018584.NET Framework: 970. .NET 5 / .NET Core - UnmanagedCallersOnly 특성을 사용한 함수 내보내기파일 다운로드1
12412정성태11/16/202020716.NET Framework: 969. .NET Framework 및 .NET 5 - UnmanagedCallersOnly 특성 사용파일 다운로드1
12411정성태11/12/202017499오류 유형: 680. C# 9.0 - Error CS8889 The target runtime doesn't support extensible or runtime-environment default calling conventions.
12410정성태11/12/202017669디버깅 기술: 174. windbg - System.TypeLoadException 예외 분석 사례
12409정성태11/12/202019510.NET Framework: 968. C# 9.0의 Function pointer를 이용한 함수 주소 구하는 방법파일 다운로드1
12408정성태11/9/202034754도서: 시작하세요! C# 9.0 프로그래밍 [8]
12407정성태11/9/202019886.NET Framework: 967. "clr!JIT_DbgIsJustMyCode" 호출이 뭘까요?
12406정성태11/8/202020848.NET Framework: 966. C# 9.0 - (15) 최상위 문(Top-level statements) [5]파일 다운로드1
12405정성태11/8/202018762.NET Framework: 965. C# 9.0 - (14) 부분 메서드에 대한 새로운 기능(New features for partial methods)파일 다운로드1
12404정성태11/7/202019371.NET Framework: 964. C# 9.0 - (13) 모듈 이니셜라이저(Module initializers)파일 다운로드1
12403정성태11/7/202018239.NET Framework: 963. C# 9.0 - (12) foreach 루프에 대한 GetEnumerator 확장 메서드 지원(Extension GetEnumerator)파일 다운로드1
12402정성태11/7/202019772.NET Framework: 962. C# 9.0 - (11) 공변 반환 형식(Covariant return types) [1]파일 다운로드1
12401정성태11/5/202019016VS.NET IDE: 153. 닷넷 응용 프로그램에서의 "My Code" 범위와 "Enable Just My Code"의 역할 [1]
12400정성태11/5/202015210오류 유형: 679. Visual Studio - "Source Not Found" 창에 "Decompile source code" 링크가 없는 경우
12399정성태11/5/202018730.NET Framework: 961. C# 9.0 - (10) 대상으로 형식화된 조건식(Target-typed conditional expressions)파일 다운로드1
12398정성태11/4/202018279오류 유형: 678. Windows Server 2008 R2 환경에서 Powershell을 psexec로 원격 실행할 때 hang이 발생하는 문제
12397정성태11/4/202018307.NET Framework: 960. C# - 조건 연산자(?:)를 사용하는 경우 달라지는 메서드 선택 사례파일 다운로드1
12396정성태11/3/202015304VS.NET IDE: 152. Visual Studio - "Tools" / "External Tools..."에 등록된 외부 명령어에 대한 단축키 설정 방법
12395정성태11/3/202018114오류 유형: 677. SSMS로 DB 접근 시 The server principal "..." is not able to access the database "..." under the current security context.
12394정성태11/3/202015744오류 유형: 676. cacls - The Recycle Bin on ... is corrupted. Do you want to empty the Recycle Bin for this drive?
12393정성태11/3/202015361오류 유형: 675. Visual Studio - 닷넷 응용 프로그램 디버깅 시 Disassembly 창에서 BP 설정할 때 "Error while processing breakpoint." 오류
12392정성태11/2/202019899.NET Framework: 959. C# 9.0 - (9) 레코드(Records) [4]파일 다운로드1
12390정성태11/1/202019619디버깅 기술: 173. windbg - System.Configuration.ConfigurationErrorsException 예외 분석 방법
12389정성태11/1/202018748.NET Framework: 958. C# 9.0 - (8) 정적 익명 함수 (static anonymous functions)파일 다운로드1
... [61]  62  63  64  65  66  67  68  69  70  71  72  73  74  75  ...