Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Entity Framework 4.1 - Code First + WCF 서비스 시 EndpointNotFoundException 오류

EF 4.1의 Code First 쿼리 결과를 WCF를 통해 노출시킬 때, 메서드가 Code First 관련 타입을 반환하는 경우 다음과 같은 오류가 발생하게 됩니다.

System.ServiceModel.EndpointNotFoundException was unhandled
  Message=There was no endpoint listening at http://.../TestWebService.svc that could accept the message. This is often caused by an incorrect address or SOAP action. See InnerException, if present, for more details.
  StackTrace:
       at System.ServiceModel.Channels.HttpChannelUtilities.ProcessGetResponseWebException(WebException webException, HttpWebRequest request, HttpAbortReason abortReason)
       at System.ServiceModel.Channels.HttpChannelFactory.HttpRequestChannel.HttpChannelAsyncRequest.CompleteGetResponse(IAsyncResult result)
       at System.ServiceModel.Channels.HttpChannelFactory.HttpRequestChannel.HttpChannelAsyncRequest.OnGetResponse(IAsyncResult result)
       at System.Net.Browser.ClientHttpWebRequest.<>c__DisplayClassa.<InvokeGetResponseCallback>b__8(Object state2)
       at System.Threading.ThreadPool.WorkItem.doWork(Object o)
       at System.Threading.Timer.ring()
  InnerException: System.Net.WebException
       Message=The remote server returned an error: NotFound.


테스트용으로 만든 동일한 웹 서비스 내의 다른 메서드들이 정상적으로 호출되는 것으로 봐서는 그 메서드에서만 문제가 있는 듯했습니다. 좀 더 원인을 찾기 위해, Fiddler로 해당 웹 메서드를 호출할 때의 응답 패킷을 살펴보니 다음과 같이 확인됩니다.

HTTP/1.1 504 Fiddler - Receive Failure
Content-Type: text/html; charset=UTF-8
Connection: close
Timestamp: 06:38:50.246

ReadResponse() failed: The server did not return a response for this request.

음... 일단, 클라이언트 측에 정상적으로 SOAP 응답이 내려오지도 않은 걸로 봐서는 웹 메서드 결괏값이 직렬화되면서 발생하는 것 같아 보였습니다. 그래서, 반환하게 될 EF CodeFirst에 참여된 결괏값을 수작업으로 직렬화 해보았습니다.

try
{
    MemoryStream ms = new MemoryStream();
    DataContractSerializer dcs = new DataContractSerializer(typeof(TestObj));
    dcs.WriteObject(ms, item);
}
catch (Exception ex)
{
    System.Diagnostics.Trace.WriteLine(ex.ToString());
}

영락없이, dbgview에는 다음과 같은 오류 메시지가 확인되었습니다.

System.Runtime.Serialization.SerializationException: Type 'System.Data.Entity.DynamicProxies.TestSource_F8AD1CA74BDE30D0189369342F1C50E8EEDDE226E498D4FFDF99220F3B969334' with data contract name 'TestSource_F8AD1CA74BDE30D0189369342F1C50E8EEDDE226E498D4FFDF99220F3B969334:http://schemas.datacontract.org/2004/07/System.Data.Entity.DynamicProxies' is not expected. Consider using a DataContractResolver or add any types not known statically to the list of known types - for example, by using the KnownTypeAttribute attribute or by adding them to the list of known types passed to DataContractSerializer. at System.Runtime.Serialization.XmlObjectSerializerWriteContext.SerializeAndVerifyType(DataContract dataContract, XmlWriterDelegator xmlWriter, Object obj, Boolean verifyKnownType, RuntimeTypeHandle declaredTypeHandle, Type declaredType)
at System.Runtime.Serialization.XmlObjectSerializerWriteContext.SerializeWithXsiTypeAtTopLevel(DataContract dataContract, XmlWriterDelegator xmlWriter, Object obj, RuntimeTypeHandle originalDeclaredTypeHandle, Type graphType)
at System.Runtime.Serialization.DataContractSerializer.InternalWriteObjectContent(XmlWriterDelegator writer, Object graph, DataContractResolver dataContractResolver)
at System.Runtime.Serialization.DataContractSerializer.InternalWriteObject(XmlWriterDelegator writer, Object graph, DataContractResolver dataContractResolver)
at System.Runtime.Serialization.XmlObjectSerializer.WriteObjectHandleExceptions(XmlWriterDelegator writer, Object graph, DataContractResolver dataContractResolver)
at System.Runtime.Serialization.XmlObjectSerializer.WriteObject(Stream stream, Object graph)
at TestService.TestWebService.GetTestList(String text) in D:\...\TestWebService.svc.cs:line 42


이 정도 구체적인 오류 메시지면 이제 구글의 도움을 받아도 될 것 같습니다.

Exposing POCO entity from EFDM through WCF to client
; http://social.msdn.microsoft.com/Forums/en/adonetefx/thread/1c37447a-e303-4947-a3ee-d2e6592aac0a

아하... 결국 EF가 반환해 준 개체가 실제 개체와의 매개 역할을 해주는 Proxy 개체이기 때문에 이를 직접적으로 직렬화하는 경우 DynamicProxies 개체 자체는 직렬화할 수 없는 개체이므로 문제가 발생하는 것입니다. 어쩌면 예전에 살펴본 WPF에서의 WCF 사용과 유사한 문제같습니다.

WPF + WCF 환경에서는 DataContract를 권장
; https://www.sysnet.pe.kr/2/0/612

자, 그럼 해결책으로 주어진 것 중에 ProxyCreationEnabled 속성을 false로 지정하는 것이 가장 적당한 해결책으로 보입니다. 그런데, 위의 글에서는 POCO를 기준으로 나온 해결책이라서 실제로 Code-First에서는 그와 같은 속성은 없고, 대신 Configuration 속성 하위에 제공되고 있습니다.

public class DBContext : DbContext
{
    public DBContext()
    {
        this.Configuration.ProxyCreationEnabled = false;
    }
}

그래서, 위와 같이 적용하고 나면 이제 정상적으로 WCF 호출이 이뤄집니다. ^^ 그래도 혹시나 싶어, 이 속성의 설정으로 인해 뭔가 더 부작용이 있지 않을까 싶어서 검색을 해보니 다음의 글이 나옵니다.

What are the downsides to turning off ProxyCreationEnabled for CTP5 of EF code first
; http://stackoverflow.com/questions/4596371/what-are-the-downsides-to-turning-off-proxycreationenabled-for-ctp5-of-ef-code-fi

Dynamic proxies are used for change tracking and lazy loading. When WCF tries to serialize object, related context is usually closed and disposed but serialization of navigation properties will automatically trigger lazy loading (on closed context) => exception.

If you turn off lazy loading you will need to use eager loading for all navigation properties you want to use (Include on ObjectQuery). Tracking changes doesn't work over WCF it works only for modification of entity which is attached to ObjectContext.


결국 제가 판단하기에는, 완전히 WCF와 같은 환경에서 직렬화를 위해 나온 속성이라고 보여질 정도이니 안심하고 사용해도 되겠습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1033정성태5/1/201133314웹: 19. IIS Express - appcmd.exe를 이용한 applicationHost.config 변경 [2]
1032정성태5/1/201130011웹: 18. IIS Express를 NT 서비스로 변경
1031정성태4/30/201130984웹: 17. IIS Express - "IIS Installed Versions Manager Interface"의 IIISExpressProcessUtility 구하는 방법 [1]파일 다운로드1
1030정성태4/30/201153388개발 환경 구성: 118. IIS Express - localhost 이외의 호스트 이름으로 접근하는 방법 [4]파일 다운로드1
1029정성태4/28/201142341개발 환경 구성: 117. XCopy에서 파일/디렉터리 확인 질문 없애기 [2]
1028정성태4/27/201139761오류 유형: 119. Visual Studio 2010 SP1 설치 후 Windows Phone 개발자 도구로 인한 재설치 문제 [3]
1027정성태4/25/201128899디버깅 기술: 40. 상황별 GetFunctionPointer 반환값 정리 - x86파일 다운로드1
1026정성태4/25/201147542디버깅 기술: 39. DebugDiag 1.1을 사용한 덤프 분석 [7]
1025정성태4/24/201129378개발 환경 구성: 116. IIS 7 관리자 - Active Directory Certification Authority로부터 SSL 사이트 인증서 받는 방법 [2]
1024정성태4/22/201130719오류 유형: 118. Windows 2008 서버에서 Event Viewer / PowerShell 실행 시 비정상 종료되는 문제 [1]
1023정성태4/20/201131602.NET Framework: 210. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 [1]
1022정성태4/19/201126851디버깅 기술: 38. .NET Disassembly 창에서의 F11(Step-into) 키 동작파일 다운로드1
1021정성태4/18/201129286디버깅 기술: 37. .NET 4.0 응용 프로그램의 Main 함수에 BreakPoint 걸기
1020정성태4/18/201130032오류 유형: 117. Failed to find runtime DLL (mscorwks.dll), 0x80004005
1019정성태4/17/201130914디버깅 기술: 36. Visual Studio의 .NET Disassembly 창의 call 호출에 사용되는 주소의 의미는? [1]파일 다운로드1
1018정성태4/16/201134712오류 유형: 116. 윈도우 업데이트 오류 - 0x8020000E
1017정성태4/14/201129153개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리파일 다운로드1
1016정성태4/13/201145329개발 환경 구성: 114. Windows Thin PC 설치 [2]
1015정성태4/9/201130620.NET Framework: 209. AutoReset, ManualReset, Monitor.Wait의 차이파일 다운로드1
1014정성태4/7/2011108129오류 유형: 115. ORA-12516: TNS:listener could not find available handler with matching protocol stack [2]
1013정성태4/7/201125902Team Foundation Server: 45. SharePoint 2010 + TFS 2010 환경에서 ProcessGuidance.html 파일 다운로드 문제
1012정성태4/6/201134653.NET Framework: 208. WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 [1]
1011정성태3/31/201136972오류 유형: 114. 인증서 갱신 오류 - The request contains no certificate template information.
1010정성태3/30/201127773개발 환경 구성: 113. 응용 프로그램 디자인 스케치 도구 - SketchFlow [4]
1009정성태3/29/201140102개발 환경 구성: 112. Visual Studio 2010 - .NET Framework 소스 코드 디버깅 [4]
1008정성태3/27/201132405.NET Framework: 207. C# - Right operand가 음수인 Shift 연산 결과 [2]
... 151  152  153  154  155  156  157  158  159  160  161  [162]  163  164  165  ...