gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 11:04:09 26 4
gpt4 key购买 nike

遇到以下问题同时发送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)静态 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>

我希望那些遇到这样问题的人能提示问题是什么,或者至少给点意见还有什么地方可以挖掘

最佳答案

抱歉自动翻译。

我没有考虑的另一个因素是输入输出流池默认的最小池是cpu cycles的core数,比如我,他等于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

关于c# - WCF - 在 100 个并发请求时接受中断请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16563539/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com