비동기 작업(WCF Data Services)
웹 응용 프로그램의 경우 내부 네트워크 내에서 실행되는 응용 프로그램보다 클라이언트와 서버 간에 보다 긴 대기 시간을 허용해야 합니다. 응용 프로그램의 성능과 사용자 환경을 최적화하려면 웹을 통해 WCF Data Services 서버에 액세스할 때 DataServiceContext 및 DataServiceQuery<TElement> 클래스의 비동기 메서드를 사용하는 것이 좋습니다.
WCF Data Services 서버가 HTTP 요청을 비동기적으로 처리하지만 WCF Data Services 클라이언트 라이브러리의 일부 메서드는 동기적이며 실행을 계속하기 전에 전체 요청-응답 교환이 완료될 때까지 기다립니다. WCF Data Services 클라이언트 라이브러리의 비동기 메서드는 이 교환이 완료될 때까지 기다리지 않으며 그 동안에 응용 프로그램에서 사용자 인터페이스의 응답을 유지할 수 있도록 합니다.
DataServiceContext 및 DataServiceQuery<TElement> 클래스에 각각 Begin 및 End로 시작하는 한 쌍의 메서드를 사용하여 비동기 작업을 수행할 수 있습니다. Begin 메서드는 작업이 완료될 때 서비스에서 호출하는 대리자를 등록합니다. End 메서드는 완료된 작업의 콜백을 처리하도록 등록된 대리자에서 호출해야 합니다. End 메서드를 호출하여 비동기 작업을 완료하는 경우 작업을 시작하는 데 사용한 것과 동일한 DataServiceQuery<TElement> 또는 DataServiceContext 인스턴스에서 완료해야 합니다. 각 Begin 메서드는 상태 개체를 콜백에 전달할 수 있는 state 매개 변수를 사용합니다. 이 상태 개체는 콜백이 제공되고 해당 End 메서드를 호출하여 비동기 작업을 완료하는 데 사용되는 IAsyncResult에서 검색됩니다. 예를 들어, DataServiceQuery<TElement> 인스턴스의 BeginExecute 메서드를 호출할 때 이 인스턴스를 state 매개 변수로 제공하면 동일한 DataServiceQuery<TElement> 인스턴스가 IAsyncResult에 의해 반환됩니다. 이 DataServiceQuery<TElement> 인스턴스는 EndExecute 메서드를 호출하여 쿼리 작업을 완료하는 데 사용됩니다. 자세한 내용은 방법: 비동기 데이터 서비스 쿼리 실행(WCF Data Service)을 참조하십시오.
참고
Silverlight용 .NET Framework에서 제공되는 클라이언트 라이브러리는 비동기 작업만 지원합니다.자세한 내용은 ADO.NET 데이터 서비스(Silverlight)를 참조하십시오.
.NET Framework 클라이언트 라이브러리는 다음 비동기 작업을 지원합니다.
작업 |
메서드 |
---|---|
DataServiceContext에서 쿼리 실행 |
|
DataServiceContext에서 일괄 처리 쿼리 실행 |
|
DataServiceContext에 관련 엔터티 로드 |
|
DataServiceContext에 개체 변경 내용 저장 |
비동기 작업에 대한 스레딩 고려 사항
다중 스레드 응용 프로그램에서 비동기 작업의 콜백으로 등록된 대리자는 Begin 메서드를 호출하는 데 사용된 것과 동일한 스레드에서 호출하지 않아도 됩니다. 같은 스레드에서 호출하면 초기 요청이 만들어집니다. 특정 스레드에서 콜백을 호출해야 하는 응용 프로그램의 경우 응답을 처리하는 End 메서드 실행을 명시적으로 원하는 스레드에 마샬링해야 합니다. 예를 들어, WPF(Windows Presentation Foundation) 기반 응용 프로그램과 Silverlight 기반 응용 프로그램에서는 Dispatcher 개체의 BeginInvoke 메서드를 사용하여 응답을 UI 스레드로 다시 마샬링해야 합니다. 자세한 내용은 Querying the Data Service (WCF Data Services/Silverlight)를 참조하십시오.