WCF单向调用 - 抛出超时异常,但消息仍然排队和处理 - 为什么/如何中止?

时间:2012-11-09 19:59:32

标签: wcf

我有一个非常简单的WCF单向服务(在IIS中托管)它正在使用basicHttpBinding:

        <service name="OptumRx.Formulary.ServiceLayer.UserRequestService" behaviorConfiguration="UserRequestBehaviors">
            <endpoint
                address=""
                binding="basicHttpBinding" bindingConfiguration="WindowsAuthBinding"
                contract="OptumRx.Formulary.ServiceLayer.IUserRequestService">
            </endpoint>
        </service>
        <client>
            <endpoint address="....."
                  binding="basicHttpBinding" bindingConfiguration="WindowsAuthBinding"
                  contract="OptumRx.Formulary.ServiceLayer.IUserRequestService">
            </endpoint>
        </client>
        <basicHttpBinding>
            <binding name="WindowsAuthBinding" sendTimeout="00:00:15" >
                <security mode="TransportCredentialOnly">
                    <transport clientCredentialType="Windows" />
                </security>
            </binding>
        </basicHttpBinding>
        <serviceBehaviors>
            <behavior name="UserRequestBehaviors">
                <serviceMetadata httpGetEnabled="true" />
                <serviceDebug includeExceptionDetailInFaults="true"/>
                <serviceThrottling maxConcurrentCalls="2" maxConcurrentInstances="2"/>
            </behavior>
        </serviceBehaviors>

代码snippits:

    // interface, declarying one way contract
    [OperationContract(IsOneWay = true)]
    void SubmitUserRequest(RequestServiceObject request);

// setting per call instancing and multiple concurrency
[ServiceBehavior(ConcurrencyMode = ConcurrencyMode.Multiple, 
                InstanceContextMode = InstanceContextMode.PerCall)]
public class UserRequestService : IUserRequestService {
}

    // how the client calls the service (client is asp.net page hosted within same site as service)
    ChannelFactory<IUserRequestService> factory = new ChannelFactory<IUserRequestService>("*");
    IUserRequestService proxyUserRequest = factory.CreateChannel();
    try {
      proxyUserRequest.SubmitUserRequest(so);
    } catch {
      // timeout error caught
    } finally {
      ((IClientChannel)proxyUserRequest).Close();
      factory.Close();
    }

调用执行一些可能很重的数据库/ IO工作,我们可能想要限制最大并发调用。如果我们已达到那个油门,那么无论如何都要停止呼叫排队?

使用上面的配置,2个调用被处理,第三个调用超时(抛出并捕获异常)。在服务跟踪视图中,我甚至看到:

 The system hit the limit set for throttle 'MaxConcurrentCalls'. Limit for this throttle was set to 2. ....

 The HTTP request to '' has exceeded the allotted timeout of 00:00:15. The time allotted to this operation may have been a portion of a longer timeout.

但是一旦前两个调用完成,第三个消息仍然存在于侦听器通道中,我猜并执行。

有没有办法在使用单向配置时中止呼叫?我希望用户知道该服务“忙”并稍后再试... ..

谢谢

0 个答案:

没有答案