WCF - 在100个并发请求中接受中断请求

时间:2013-05-15 11:13:35

标签: c# wcf

面对以下问题,同时发送100个请求,服务器开始减慢采用新查询,前100个请求触发执行1分钟的功能,等待执行结束,101请求我从浏览器函数发送一个简短的调用,打印字符串和仍然并行运行的请求数。

因此在完成所有100个请求并开始在流中工作之后,101函数很快并显示100个线程现在并行运行。

在互联网上观看了很多信息,一切似乎应该做但仍然没有结果

使用NF 4.5

类属性设置为并行C#代码

[CallbackBehavior(UseSynchronizationContext = false)]
[ServiceBehavior(InstanceContextMode = InstanceContextMode.PerCall, ConcurrencyMode = ConcurrencyMode.Multiple, MaxItemsInObjectGraph = 2147483646)]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
[ServiceContract(SessionMode = SessionMode.NotAllowed)]

函数仿真加载1分钟C#代码

private static int threads11 = 0;

[OperationContract]
[WebGet(BodyStyle = WebMessageBodyStyle.Bare, ResponseFormat = WebMessageFormat.Json)]
public string loadConcurency()
{
    threads11++;
    var count = 0;
    while (count < 6000)
    {
        count++;
        Thread.Sleep(10);
    }
    threads11--;
    return "1";
}

功能测试统计C#代码

[OperationContract]
[WebGet(BodyStyle = WebMessageBodyStyle.Bare,
        ResponseFormat = WebMessageFormat.Json)]

public string ReportTest()
{
    try
    {
        StringBuilder response = new StringBuilder().AppendLine("threads=" + threads11.ToString() + "; ");
        response.AppendLine();

        return response.ToString();
    }
    catch (Exception ex)
    {
        return ex.ToString() + (ex.InnerException == null ? "" : ex.InnerException.ToString());
    }
}

serviceThrottling设置得很高

<behavior name="ServiceBehavior">
  <serviceMetadata httpGetEnabled="True" />
  <serviceDebug includeExceptionDetailInFaults="true" />
  <serviceThrottling maxConcurrentCalls="3000" maxConcurrentSessions="30000" maxConcurrentInstances="3000" />
</behavior>

我希望遇到这样的问题的人会提示出什么问题,或者至少提出建议去哪里挖掘

1 个答案:

答案 0 :(得分:2)

抱歉自动翻译。

我没有考虑另一个因素是输入和输出流池 默认的最小池是CPU周期的核心数,例如I,他等于4 最大值是1023,但是当我试图制作100个线程时为什么会出现问题?

答案是,当我们超出最小阈值时,服务器不会立即分配新线程,并等待约0.5秒释放其中一个员工,只有这样才能找到空闲分配新线程.. 现在考虑到我需要保持100个连接,前4个用于立即处理,其他96个用了大约96秒* 0.5 = 48秒,这是我的下一个101测试呼叫等待 48秒!

溶液:

ThreadPool.SetMinThreads (4, 100);

我确信我的回答和我的工作对某人有用,并且不会给他们很多时间来杀人:)

来源:

http://blogs.msdn.com/b/wenlong/archive/2010/02/11/why-does-wcf-become-slow-after-being-idle-for-15-seconds.aspx

http://msdn.microsoft.com/ru-ru/library/system.threading.threadpool.setminthreads.aspx

WCF performance, latency and scalability