面对以下问题,同时发送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>
我希望遇到这样的问题的人会提示出什么问题,或者至少提出建议去哪里挖掘
答案 0 :(得分:2)
抱歉自动翻译。
我没有考虑另一个因素是输入和输出流池 默认的最小池是CPU周期的核心数,例如I,他等于4 最大值是1023,但是当我试图制作100个线程时为什么会出现问题?
答案是,当我们超出最小阈值时,服务器不会立即分配新线程,并等待约0.5秒释放其中一个员工,只有这样才能找到空闲分配新线程.. 现在考虑到我需要保持100个连接,前4个用于立即处理,其他96个用了大约96秒* 0.5 = 48秒,这是我的下一个101测试呼叫等待 48秒! 强>
溶液:
ThreadPool.SetMinThreads (4, 100);
我确信我的回答和我的工作对某人有用,并且不会给他们很多时间来杀人:)
来源:
http://msdn.microsoft.com/ru-ru/library/system.threading.threadpool.setminthreads.aspx