在WCF中实现队列

时间:2013-01-24 13:28:19

标签: wcf

我有一个简单的WCF服务,它在指定为param的位置创建一个目录。 该服务作为Windows服务托管,并在管理员帐户下运行。

InstanceContextMode是Single,因此是Concurrency。

该方法在创建后返回目录位置的字符串。

客户端正在使用ASP.NET从另一台计算机访问此服务。 他有一个用例,他在几秒钟内多次点击页面上的按钮,比如在2秒内点击它5次。发生的事情是该服务仅创建2个或3个文件夹,而不是全部5个文件夹。

我知道WCF中有一个默认的排队机制,对于我的服务,它要么不工作,要么我没有写它来使用该机制。

我该如何解决这个问题。

这是按钮单击的ASP.NET代码

protected void Button1_Click(object sender, EventArgs e)
{
    ClientClass objClientClass = new ClientClass();

    string returnValue = string.Empty;
    Random random = new Random();

    string uid = random.Next().ToString();
    returnValue = objClientClass.StartWorkflow(uid);
    Label1.Text = returnValue;

}

这是主机的app.config:

<configuration>
  <system.diagnostics>
   <sources>
    <source name="System.ServiceModel"
               switchValue="All"
               propagateActivity="true">
    <listeners>
      <add name="traceListener" />
    </listeners>
   </source>
  <source name="System.ServiceModel.MessageLogging"
               switchValue="All"
               propagateActivity="true">
    <listeners>
      <add name="traceListener" />
    </listeners>
  </source>
</sources>
<sharedListeners>
  <add name="traceListener"
          type="System.Diagnostics.XmlWriterTraceListener"
          initializeData="Traces.svclog" />
</sharedListeners>

</system.diagnostics>  
<system.web>
<compilation debug="true"></compilation>
 </system.web>
 <system.serviceModel>
  <diagnostics>
  <messageLogging logEntireMessage="true"
                  logMessagesAtServiceLevel="false"
                  logMessagesAtTransportLevel="false"
                  logMalformedMessages="true"
                  maxMessagesToLog="5000"
                  maxSizeOfMessageToLog="2000">
  </messageLogging>
</diagnostics>
<behaviors>
  <serviceBehaviors>
    <behavior name="NewBehavior">
      <serviceMetadata httpGetEnabled="true" />
      <serviceThrottling maxConcurrentCalls="1" maxConcurrentSessions="5" maxConcurrentInstances="5" />
    </behavior>
  </serviceBehaviors>
</behaviors>
<services>
  <service behaviorConfiguration="NewBehavior" name="Utilities.WS.SampleWebService.Jobs">
    <endpoint address="" binding="basicHttpBinding" bindingConfiguration=""
        contract="Utilities.WS.SampleWebService.IJobs" />
    <endpoint address="mex" binding="mexHttpBinding" contract="IMetadataExchange"/>
    <host>
      <baseAddresses>
        <add     baseAddress="http://00.00.000.00:8732/Utilities.WS.SampleWebService.Jobs" />
      </baseAddresses>
      </host>
    </service>
  </services>
 </system.serviceModel>
</configuration>

问候。

1 个答案:

答案 0 :(得分:0)

步骤1.从客户端ping(服务器端ASP.NET代码,而不是浏览器),它是否可以到达托管WCF服务的计算机?防火墙位于您的网络服务器和托管WCF的位置之间?

步骤2. SVC日志 从配置文件中设置svclog,

<configuration>
   <system.diagnostics>
      <sources>
            <source name="System.ServiceModel" 
                    switchValue="Information, ActivityTracing"
                    propagateActivity="true">
            <listeners>
               <add name="traceListener" 
                   type="System.Diagnostics.XmlWriterTraceListener" 
                   initializeData= "c:\log\Traces.svclog" />
            </listeners>
         </source>
      </sources>
   </system.diagnostics>
</configuration>

然后从命令提示符处使用SvcTraceViewer - 查找红色。

步骤3.在操作中添加更多日志记录,看看是否有任何实际执行

http://msdn.microsoft.com/en-us/library/ms732023(v=vs.110).aspx