채널 팩터리 및 캐싱
WCF 클라이언트 애플리케이션에서는 ChannelFactory<TChannel> 클래스를 사용하여 WCF 서비스와의 통신 채널을 만듭니다. ChannelFactory<TChannel> 인스턴스를 만들 때는 다음 작업이 필요하기 때문에 약간의 오버헤드가 발생합니다.
ContractDescription 트리 생성
필요한 모든 CLR 형식 반영
채널 스택 생성
리소스 삭제
이 오버헤드를 최소화하기 위해 사용자가 WCF 클라이언트 프록시를 사용할 때 WCF가 채널 팩터리를 캐시할 수 있습니다.
팁
ChannelFactory<TChannel> 클래스를 직접 사용하면 채널 팩터리 생성을 직접 제어할 수 있습니다.
ServiceModel Metadata 유틸리티 도구(Svcutil.exe)로 생성된 WCF 클라이언트 프록시는 ClientBase<TChannel>에서 파생됩니다. ClientBase<TChannel>는 채널 팩터리 캐싱 동작을 정의하는 정적 CacheSetting 속성을 정의합니다. 캐시 설정은 특정 형식에 대해 지정합니다. 예를 들어 ClientBase<ITest>.CacheSettings
를 아래 정의된 값 중 하나로 설정하면 형식이 ITest
인 프록시/ClientBase에만 영향을 미칩니다. 특정 ClientBase<TChannel>에 대한 캐시 설정은 첫 번째 프록시/ClientBase 인스턴스가 만들어지는 즉시 변경할 수 없게 됩니다.
캐싱 동작 지정
캐싱 동작은 CacheSetting 속성을 다음 값 중 하나로 설정하여 지정할 수 있습니다.
캐시 설정 값 | 설명 |
---|---|
AlwaysOn | 응용 프로그램 도메인 안의 모든 ClientBase<TChannel> 인스턴스가 캐싱에 참여할 수 있습니다. 개발자는 캐싱에 대해 보안 상의 문제가 없는 것으로 판단했습니다. ClientBase<TChannel>에서 “보안과 관련된” 속성을 액세스하더라도 캐싱은 해제되지 않습니다. “보안과 관련된” ClientBase<TChannel> 속성은 ClientCredentials, Endpoint 및 ChannelFactory입니다. |
Default | 구성 파일에 정의된 엔드포인트에서 만든 ClientBase<TChannel> 인스턴스만 응용 프로그램 도메인 안의 캐싱에 참여할 수 있습니다. 해당 응용 프로그램 도메인에서 프로그래밍 방식으로 생성된 모든 ClientBase<TChannel> 인스턴스는 캐싱에 참여하지 않습니다. 또한, “보안과 관련된” 임의의 속성을 액세스하면 ClientBase<TChannel> 인스턴스에 대한 캐싱이 사용하지 않도록 설정됩니다. |
AlwaysOff | 해당 응용 프로그램 도메인 안에서 특정 형식의 ClientBase<TChannel>의 모든 인스턴스에 대한 캐싱이 해제됩니다. |
다음 코드 조각에서는 CacheSetting 속성을 사용하는 방법을 보여 줍니다.
class Program
{
static void Main(string[] args)
{
ClientBase<ITest>.CacheSettings = CacheSettings.AlwaysOn;
foreach (string msg in messages)
{
using (TestClient proxy = new TestClient (new BasicHttpBinding(), new EndpointAddress(address)))
{
// ...
proxy.Test(msg);
// ...
}
}
}
}
// Generated by SvcUtil.exe
public partial class TestClient : System.ServiceModel.ClientBase, ITest { }
위 코드에서 TestClient
의 모든 인스턴스는 같은 채널 팩터리를 사용합니다.
class Program
{
static void Main(string[] args)
{
ClientBase<ITest>.CacheSettings = CacheSettings.Default;
int i = 1;
foreach (string msg in messages)
{
using (TestClient proxy = new TestClient ("MyEndpoint", new EndpointAddress(address)))
{
if (i == 4)
{
ServiceEndpoint endpoint = proxy.Endpoint;
... // use endpoint in some way
}
proxy.Test(msg);
}
i++;
}
}
// Generated by SvcUtil.exe
public partial class TestClient : System.ServiceModel.ClientBase, ITest {}
위 예제에서 TestClient
의 모든 인스턴스는 #4 인스턴스를 제외하고 같은 채널 팩터리를 사용합니다. 인스턴스 #4는 전용으로 특수하게 만들어진 채널 팩터리를 사용합니다. 이 설정은 특정 엔드포인트가 같은 채널 팩터리 형식(이 경우 ITest
)의 다른 엔드포인트와 다른 보안 설정이 필요한 시나리오에 적용됩니다.
class Program
{
static void Main(string[] args)
{
ClientBase<ITest>.CacheSettings = CacheSettings.AlwaysOff;
foreach (string msg in messages)
{
using (TestClient proxy = new TestClient ("MyEndpoint", new EndpointAddress(address)))
{
proxy.Test(msg);
}
}
}
}
// Generated by SvcUtil.exe
public partial class TestClient : System.ServiceModel.ClientBase, ITest {}
위 예제에서 TestClient
의 모든 인스턴스는 다른 채널 팩터리를 사용합니다. 이는 각 엔드포인트가 다른 보안 요구사항을 가지고 있고 캐시하는 의미가 없을 때 유용합니다.