我有一个简单的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>
问候。
答案 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